一、问题背景
SSH远程执行脚本报错"command not found",且环境变量不生效,执行env命令后发现打印出来的环境变量少了很多。
原因是之前将环境变量配置在了/etc/profile中,但是SSH远程执行脚本时实际上执行的是non-login shell,而non-login shell不会读取/etc/profile配置文件。
二、关于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的。
Linux的环境配置文件
运行man bash可以查看环境配置文件的说明,以CentOS7为例:
# man bash
1. /etc 下的是系统环境配置,对所有用户有效,但是/etc/profile只对login shell有效,而/etc/bashrc对login shell和non-login shell都有效。
2. ~下的是当前用户环境配置,当前用户环境配置会继承/etc系统环境配置。
login shell和non-login shell读取的环境变量配置文件