环境变量问题总结
关于login shell和non-login shell
简单来说,用SSH客户端(比如Putty)登陆Linux系统时,要求输入用户名/密码登录或根据SSH key登录时,就是login shell。
而在A机器上使用SSH免密码登录B机器,在B机器上执行Shell脚本,就是non-login shell。
ansible在目标机器上远程执行Shell脚本时,也是non-login shell,因为Ansible是基于SSH的。
运行man bash可以查看环境配置文件的说明,以CentOS7为例:(ubuntu会有一些差异)
-
- /etc 下的是系统环境配置,对所有用户有效,但是/etc/profile只对login shell有效,而/etc/bashrc对login shell和non-login shell都有效。
-
- ~下的是当前用户环境配置,当前用户环境配置会继承/etc系统环境配置。
- 3 login shell加载环境变量的顺序是:① /etc/profile ② ~/.bash_profile ③ ~/.bashrc ④ /etc/bashrc
- 4 而non-login shell加载环境变量的顺序是:** ① ~/.bashrc ② /etc/bashrc**
**简单讲:为了满足各种情况 我们应该把环境变量配置到 /etc/bashrc 文件中(ubuntu 对应的是/etc/bash.bashrc ) **
Centos配置
Ubuntu配置
注意事项
- 1. ansible这类远程执行的non-login shell 并不会加载/etc/profile和/.bash_profile下的环境变量,只是加载/.bashrc和/etc/bashrc
- 2. 如果需要在ansible中执行需要特定环境变量的命令,可以在执行前source一下 ~/.bash_profile, 或者将环境变量写在~/.bashrc /etc/bashrc