在许多服务器上通过 SSH 自动运行命令

在许多服务器上通过 SSH 自动运行命令

.txt 文件中有一个 IP 地址列表,例如:

1.1.1.1
2.2.2.2
3.3.3.3

每个 IP 地址后面都有一个服务器,并且每个服务器上都有一个在端口 22 上运行的 sshd。并非每个服务器都在列表中known_hosts(在我的 PC 上,Ubuntu 10.04 LTS/bash)。

如何在这些服务器上运行命令并收集输出?

理想情况下,我想在所有服务器上并行运行命令。

我将在所有服务器上使用公钥身份验证。

以下是一些潜在的陷阱:

  • ssh 提示我将给定的服务器 ssh 密钥放入我的known_hosts文件中。
  • 给定的命令可能返回非零退出代码,表明输出可能无效。我需要认识到这一点。
  • 可能无法与给定服务器建立连接,例如由于网络错误。
  • 应该有一个超时,以防命令运行时间超过预期或服务器在运行命令时出现故障。

服务器是 AIX/ksh(但我认为这并不重要。

答案1

有几种工具允许您同时登录多台计算机并在多台计算机上执行一系列命令。这里有几个:

答案2

如果你喜欢Python脚本编写比 bash脚本编写更多,那么织物可能是适合您的工具。

来自面料主页:

Fabric 是一个 Python(2.5 或更高版本)库和命令行工具,用于简化 SSH 在应用程序部署或系统管理任务中的使用。

它提供了一套基本的操作,用于执行本地或远程 shell 命令(通常或通过 sudo)和上传/下载文件,以及提示运行用户输入或中止执行等辅助功能。

典型用途包括创建包含一个或多个函数的 Python 模块,然后通过 fab 命令行工具执行它们。

答案3

假设您无法安装 pssh 或其他软件,您可以执行类似以下操作:

tmpdir=${TMPDIR:-/tmp}/pssh.$$
mkdir -p $tmpdir
count=0
while IFS= read -r userhost; do
    ssh -n -o BatchMode=yes ${userhost} 'uname -a' > ${tmpdir}/${userhost} 2>&1 &
    count=`expr $count + 1`
done < userhost.lst
while [ $count -gt 0 ]; do
    wait $pids
    count=`expr $count - 1`
done
echo "Output for hosts are in $tmpdir"

答案4

非常基本的设置:

for host in $(cat hosts.txt); do ssh "$host" "$command" >"output.$host"; done

使用名称/密码进行身份验证确实不是一个好主意。您应该为此设置一个私钥:

ssh-keygen && for host in $(cat hosts.txt); do ssh-copy-id $host; done

相关内容