最新在搭建新的产品环境就遇到了一个坑,使用js 的node-ssh module执行远程机器的sh脚本的时候发现,无法获取全局的环境变量。我们知道linux机器的全局环境变量的设置是在/etc/profile这个文件中的。我在这个文件中添加了JAVA_HOME的环境变量,并将java的bin目录添加到了$PATH中,但是通过ssh执行远程脚本的时候拿到的JAVA_HOME的值是空的,但是如果通过xshell工具ssh到远程主机就可以拿到环境变量,当时不理解是为什么?后台通过查了一些资料才了解大致原因。
原来通过ssh执行远程的命令或者脚本和通过ssh登录到远程主机后在执行脚本这两种方式的bash模式不同。bash工作模式主要分为:login + interactive,login + non-interactive ,non-login + interactive ,non-login + non-interactive 。login 是指需要输入用户名和密码登陆的 shell; interactive 顾名思义为交互式,命令的标准输入与输出为该 bash 绑定到的终端。
* login + interactive
* 登陆 Linux 获取的第一个 shell
* 通过 ssh user_name @ romote_ip 登陆获取到的 shell
* 运行命令 bash -l 进入的 shell
* 首先读取 /etc/profile 文件
* 再从下面三个文件读取到第一个存在的文件
~/.bash_profile、~/.bash_login、~/.profile
etc/profile 会依次读取 /etc/profile.d 下所有文件
* login + non-interactive
*