环境变量配置说明
- Linux的环境变量可在多个文件中配置,如/etc/profile,/etc/profile.d/*.sh,/.bashrc,/.bash_profile等,
下面说明上述几个文件之间的关系和区别
- bash的运行模式可分为login shell和non-login shell
例如,我们通过终端,输入用户名、密码,登录系统之后,得到就是一个login shell。
而当我们执行以下命令ssh node3 command,在node3 执行command的就是一个non-login shell。
- 这两种shell的主要区别在于,它们启动时会加载不同的配置文件,login shell启动时会加载/etc/profile,/.bash_profile,/.bashrc。non-login shell启动时会加载~/.bashrc。
而在加载/.bashrc(实际是/.bashrc中加载的/etc/bashrc)或/etc/profile时,都会执行如下代码片段,
- 因此不管是login shell还是non-login shell,启动时都会加载/etc/profile.d/*.sh中的环境变量。所以,可以把环境变量都放在/etc/profile.d下的某个sh文件中,如下:
export JAVA_HOME=/export/server/jdk1.8.0_241
export PATH=:$JAVA_HOME/bin:$PATH
#export HADOOP_HOME=/export/server/hadoop-2.7.5
export HADOOP_HOME=/export/soft/hadoop-3.1.3
export PATH=:$HADOOP_HOME/bin:$HADOOP_HOME/sbin:$PATH
export KAFKA_HOME=/export/server/kafka_2.12-2.4.1
export PATH=:$PATH:${KAFKA_HOME}
export HADOOP_CONF_DIR=${HADOOP_HOME}/etc/hadoop
export HADOOP_CLASSPATH=`hadoop classpath`