环境 centos6.5
状况 A机器 ssh user@B机器 ‘command’ 执行命令(B机器添加了对A机器的信任)
提示 'bash: node: command not found'

使用 ssh user@B机器 手动执行命令是没有问题的 echo $PATH;node -v 也是正常的

1
2
3
4
5
-bash-4.1$ ssh root@B机器IP
Last login: Sat Jun 18 15:14:35 2016 from A机器IP
[root@IOS-Account ~]# echo $PATH;node -v
/data/soft/node/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/sbin:/root/bin
v4.4.4

使用 ssh user@B机器 'echo $PATH;node -v' 打印的环境变量路径 与login 方式打印的路径不一样.

1
2
3
-bash-4.1$ ssh root@B机器IP 'echo $PATH;node -v'
/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/sbin
bash: node: command not found

根据这篇文章, 找到了原因.
以下这两个登录方式的环境变量是不一样的
ssh user@ip 登录以后是有交互的
ssh user@ip 'command' 登录以后直接执行命令,然后退出

最后我的解决方式是

1
ssh root@B机器IP 'source ~/.bash_profile;echo $PATH;node -v'

结果:

1
2
3
-bash-4.1$ ssh root@B机器IP 'source ~/.bash_profile;echo $PATH;node -v'
/data/soft/node/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/sbin:/sbin:/root/bin
v4.4.4
感谢您的阅读,本文由 smallwhite's Blog 版权所有。如若转载,请注明出处:smallwhite's Blog(https://smallwhite.ml/pub/uncategorized/jie-jue-ssh-user-ip-command-chu-xian-command-not-found-de-wen-ti.html
pm2 自定义log, pid 等日志文件位置
ssh连接远程主机执行脚本的环境变量问题