ansible 中 JAVA_HOME不生效问题

解决方案

~/.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

原文地址:https://www.cnblogs.com/Peter2014/p/11645734.html