解决方案
~/.bash_profile 是交互式、login 方式进入 bash 运行的,意思是只有用户登录时才会生效。
~/.bashrc 是交互式 non-login 方式进入 bash 运行的,用户不一定登录,只要以该用户身份运行命令行就会读取该文件。
根据上述两者的区别,ansible是以non-login方式运行的,所以需要将环境变量配置在 ~/.bashrc中才能成功
扩展阅读
转载地址: https://www.jianshu.com/p/b5c4113b28d7?utm_campaign
-
我们登录执行的是login shell,会加载/etc/profile,~/.bash_profile
-
ansible这类ssh远程执行是non-login shell,不会加载etc/profile,/.bash_profile,而是加载etc/bashrc和/.bashrc
关于login shell 与 non-login shell
《鸟哥的Linux私房菜基础学习篇》里这样描述/etc/profile及/etc/bashrc的区别:
-
login shell:取得bash时需要完整的登入流程的,就称为login shell。举例来说,你要由tty1~tty6登入,需要输入用户的账号和密码,此时取得的bash就称为『login shell』。
-
non-login shell:取得bash接口的方法不需要重复登入的举动,举例来说:
(1)你以Xwindow登入Linux后,再以X的图形化接口启动终端机,此时那个终端接口并没有需要再次的输入账号和密码,那个bash的环境就称为non-login shell了。
(2)你在原本的bash环境下再次下达bash这个命令,同样的也没有输入账号密码,那第二个bash (子程序)也是non-login shell 。
我们查看~/.bash_profile,发现里面有这样一段内容:
if [ -f ~/.bashrc ]; then
. ~/.bashrc
fi
当~/.bashrc存在时,login shell 会引入~/.bashrc的环境变量
我们再看~/.bashrc,发现一段类似的内容
if [ -f /etc/bashrc ]; then
. /etc/bashrc
fi
当/etc/bashrc存在时,login shell会引入/etc/bashrc内的环境变量
那么:
-
login shell加载环境变量的顺序是:① /etc/profile ② ~/.bash_profile ③ ~/.bashrc ④ /etc/bashrc
-
而non-login shell加载环境变量的顺序是: ① ~/.bashrc ② /etc/bashrc