Linux:centos6.5
工具:CRT
最近在服务器上遇到了这么一个问题:
1、有两个账号:developer
和webuser
;
其中webuser
用户可以直接使用play命令
,比如可以执行:
[webuser@10-10-104-111 ~]$ play version
~ _ _
~ _ __ | | __ _ _ _| |
~ | '_ \| |/ _' | || |_|
~ | __/|_|\____|\__ (_)
~ |_| |__/
~
~ play! 1.2.7, http://www.playframework.org
~ framework ID is ggservicemanager
~
1.2.7
而用户developer
却不能使用,会报play
命令找不到。
这里我先贴出 具体原因,后面再简单分析下;
原因是:webuser
用户 其在~/.bash_profile
目录中进行设置:
PATH=$PATH:$HOME/bin
GGOPENAPI_HOME=$HOME/gogoal_platform/ggopenapi
export PATH=$PATH:$GGOPENAPI_HOME:/data/play.1.2.7
而developer
用户,并没有相应的设置;
那么问题来了 ~/.bash_profile
,是啥?
~/.profile: 在登录时用到的第三个文件 是.profile文件,每个用户都可使用该文件输入专用于自己使用的shell信息,当用户登录时,该文件仅仅执行一次!默认情况下,他设置一些环境变量,执行用户的.bashrc文件。
~/.bashrc:该文件包含专用于你的bash shell的bash信息,当登录时以及每次打开新的shell时,该该文件被读取。不推荐放到这儿,因为每开一个shell,这个文件会读取一次,效率 上讲不好。
~/.bash_profile:每个用户都可使用该文件输入专用于自己 使用的shell信息,当用户登录时,该文件仅仅执行一次!默认情况下,他设置一些环境变量,执行用户的.bashrc文件。~/.bash_profile 是交互式、login 方式进入 bash 运行的~/.bashrc是交互式 non-login 方式进入 bash 运行的通常二者设置大致相同,所以通常前者会调用后者。
~./bash_login:不推荐使用这个,这些不会影响图形界面。而且.bash_profile优先级比bash_login高。当它们存在时,登录shell启动时会读取它们。
~/.bash_logout:当每次退出系统(退出bash shell)时,执行该文件.
~/.pam_environment:用户级的环境变量设置文件。
/etc/profile:在登录时,操作系统定制用户环境时使用的第一个文件,此文件为系统的每个用户设置环境信息,当用户第一次登录时,该文件被执行。并从/etc/profile.d目录的配置文件中搜集shell的设置。这个文件一般就是调用/etc/bash.bashrc文件。
/etc/bash.bashrc:系统级的bashrc文件,为每一个运行bash shell的用户执行此文件.当bash shell被打开时,该文件被读取.
/etc/environment: 在登录时操作系统使用的第二个文件,系统在读取你自己的profile前,设置环境文件的环境变量。
首先来做一个实验:
先将export LANG=zh_CN
加入/etc/profile
,退出系统重新登录,登录提示显示英文。将/etc/profile
中的export LANG=zh_CN
删除,将LNAG=zh_CN
加入/etc/environment
,退出系统重新登录,登录提示显示中文。
用户环境建立的过程中总是先执行/etc/profile
然后在读取/etc/environment
。为什么会有如上所叙的不同呢?
应该是先执行/etc/environment,后执行/etc/profile
。
/etc/environment
是设置整个系统的环境,而/etc/profile
是设置所有用户的环境,前者与登录用户无关,后者与登录用户有关。
系统应用程序的执行与用户环境可以是无关的,但与系统环境是相关的,所以当你登录时,你看到的提示信息,比如日期、时间信息的显示格式与系统环境的LANG是相关的,缺省LANG=en_US
,如果系统环境LANG=zh_CN
,则提示信息是中文的,否则是英文的。
对于用户的SHELL初始化而言是先执行/etc/profile
, 再读取文件/etc/environment
.
对整个系统而言是先执行/etc/environment。这样理解正确吗?
/etc/enviroment -->/etc/profile --> $HOME/.profile -->$HOME/.env (如果存在)
/etc/profile
是所有用户的环境变量
/etc/enviroment
是系统的环境变量
登陆系统时shell读取的顺序应该是
/etc/profile ->/etc/enviroment -->$HOME/.profile-->$HOME/.env
原因应该是用户环境和系统环境的区别了
如果同一个变量在用户环境(/etc/profile
)和系统环境(/etc/environment
) 有不同的值那应该是以用户环境为准了。
在shell中执行程序时,shell会提供一组环境变量。export可新增,修改或删除环境变量,供后续执行的程序使用。export的效力仅及于该此登陆操作
在登录Linux时要执行文件的过程如下:
在刚登录Linux时,首先启动/etc/profile
文件,然后再启动用户目录下的 ~/.bash_profile
、 ~/.bash_login
或 ~/.profile
文件中的其中一个,执行的顺序为:~/.bash_profile、 ~/.bash_login、 ~/.profile
。如果 ~/.bash_profile
文件存在的话,一般还会执行 ~/.bashrc
文件。因为在 ~/.bash_profile
文件中一般会有下面的代码:
# .bashrc
# Source global definitions
if [ -f /etc/bashrc ]; then
. /etc/bashrc
fi
# User specific aliases and functions
所以,~/.bashrc会调用/etc/bashrc文件。最后,在退出shell时,还会执行~/.bash_logout文件。
执行顺序为:/etc/profile -> (~/.bash_profile | ~/.bash_login | ~/.profile) -> ~/.bashrc-> /etc/bashrc -> ~/.bash_logout
由以上分析可知:
/etc/profile全局的,随系统启动设置【设置这个文件是一劳永逸的办法】
/root/.profile
和/home/myname/.profile
只对当前窗口有效。
/root/.bashrc
和 /home/yourname/.bashrc
随系统启动,设置用户的环境变量【平时设置这个文件就可以了】
.profile
(由Bourne Shell和Korn Shell使用)和.login
(由C Shell使用)两个文件是.bash_profile
的同义词,目的是为了兼容其它Shell
。在Debian
中使用.profile
文件代 替.bash_profile
文件。
参考地址:
Ubuntu系统环境变量详解
Linux-profile、bashrc、bash_profile之间的区别和联系
Linux中profile、bashrc、bash_profile之间的区别和联系