当你使用ansible 一键部署 jdk、zookeeper、kafka 等需要加载环境变量的时候会遇到source 加载环境变量无法成功,ansible显示执行成功的,确实命令执行成功了,但是不生效。
那是由于 ansible 是使用 non-login 免密登录到其他节点进行操作的,详情请往下看
ssh登录有两种模式:
1. login shell
用SSH客户端(比如Putty、xshell)登陆Linux系统时,要求输入用户名/密码登录或根据SSH key登录时,就是login shell。
2. non-login shell
而在 A 机器上使用SSH免密码登录 B 机器,就是non-login shell
环境变量配置文件加载的顺序:
也是两种情况:
1.login shell 加载的顺序如下:
/etc/profile --> ~.bash_profile --> /etc/bashrc --> ~.bashrc
2.non-login shell 加载顺序如下:
/etc/bashrc --> ~.bashrc
ansible 就是利用 ssh免密登录到其他节点上执行相关操作,所以使用 non-login 登录模式。
当你 使用 source 命令加载 /etc/profile.d/xxx.sh 环境变量的时候,无法加载成功。
因为 non-login 模式登录是无法加载 /etc/profile.d/ 这个目录的文件的,最高加载到 /etc/bashrc 这个文件级别。
所以我将 环境变量配置到 /etc/bashrc 文件中,然后加载,再使用ansible使用的话是可以使用的。
如下图,是我在使用ansible部署 zookeeper 集群中加载的 jdk 与 zookeeper 的环境变量
注意:
这些环境变量使用ansible是可以调用的,但在机器本地还是需要手动加载一下 /etc/profiled.d/ 目录下对应的配置文件后才可以使用。