明明配置了JAVA_HOME,Jenkins却找不到java命令的执行路径。
调试之后发现,原因是:当修改了 slave 节点上的 shell 环境变量之后,Jenkins执行Job时并不会更新环境变量。
粗暴的解决方法是:让 Job 主动执行source /etc/profile
来加载环境变量,但这需要经常修改Job,碍事。
多次调试,发现:
- 当 Jenkins master 通过 SSH 连接到 slave 之后(以 notty 方式连接,不创建终端),会执行 java -jar remoting.jar 命令,保持运行一个客户端。
- master 每次连接 slave 时,不会加载 /etc/profile 和 ~/.bash_profile ,只会加载 /etc/bashrc 和 ~/.bashrc 。
因此,需要在/etc/bashrc 文件中调用 /etc/profile ,或者在 slave 的配置页面添加 refix Start Agent Command :source /etc/profile;source ~/.bash_profile;
。如下图:
- 客户端执行的所有 shell 命令都会继承它的 shell 环境变量。因此,当用户修改 shell 环境变量时,客户端不会自动更新,必须手动将 slave 断开重连。