0

我正在使用这个名为pssh的工具一起 ssh 到多个主机

使用它的语法是:

pssh [OPTIONS] command [...]

例如:

pssh -h hosts.txt uptime

这里 hosts.txt 是包含我所有主机的 IP 地址的文件。上面提到的命令工作得很好。即使我用 ls 替换 uptime 它也可以正常工作并向我显示相应机器上所有文件的正确内容。

问题是,如果我用 echo $PATH 替换该命令,那么它会显示我的路径

如果我使用这个命令:

pssh -h ips.txt which java

然后对于所有主机它向我显示此错误:

which: no java in (/usr/local/bin:/bin:/usr/bin)

如果我使用普通的 ssh 命令手动 ssh 到其中一个主机 ()

我执行 which 命令或查看 $PATH 变量,然后看到:

-bash-3.2$ echo $PATH
/home/xx/bin64:/home/xx/bin:/usr/kerberos/bin:/usr/local/sbin:/usr/sbin:/sbin:/usr/local/bin:/bin:/usr/bin
-bash-3.2$ which java
/home/xx/bin/java
-bash-3.2$ 

所以这表明至少有一台机器安装了 java 并配置了正确的路径。那么有人可以告诉我为什么我不能让这个命令适用于所有主机吗?

4

1 回答 1

2

您要连接的服务器可能会$PATH根据远程运行的 shell 是登录 shell 还是交互式 shell 设置不同的值。当您以交互方式 ssh 时,会在服务器上调用一个交互式登录 shell。当您以非交互方式 ssh 时,将调用非交互、非登录 shell(可以-c选择直接运行指定命令而不进入交互模式)。

许多 shell 提供不同的启动文件,具体取决于它们是作为登录 shell 和/或交互式 shell 调用的。例如,bash 仅在它是登录 shell 时才读取~/.profile(或变体),并且~/.bashrc仅当它是一个 intractive shell 时。服务器可能会设置一个$PATH包含来自这些启动文件之一的 Java 目录。

解决方案是设置环境变量,例如$PATHfrom/etc/environment而不是 shell 启动文件。

于 2013-06-17T18:15:56.837 回答