Lan*_*nes 55 scripting ssh parallelism
.txt 文件中有一个 IP 地址列表,例如:
1.1.1.1
2.2.2.2
3.3.3.3
Run Code Online (Sandbox Code Playgroud)
每个 IP 地址后面都有一个服务器,并且在每个服务器上都有一个在端口 22 上运行的 sshd。并非每个服务器都在known_hosts
列表中(在我的 PC 上,Ubuntu 10.04 LTS/bash)。
如何在这些服务器上运行命令并收集输出?
理想情况下,我想在所有服务器上并行运行这些命令。
我将在所有服务器上使用公钥身份验证。
以下是一些潜在的陷阱:
known_hosts
文件中。服务器是 AIX/ksh(但我认为这并不重要。
Ric*_*rri 18
如果您更喜欢Python脚本而不是
bash
脚本,那么Fabric可能是适合您的工具。
Fabric 是一个 Python(2.5 或更高版本)库和命令行工具,用于简化 SSH 在应用程序部署或系统管理任务中的使用。
它提供了一套基本的操作来执行本地或远程 shell 命令(通常或通过 sudo)和上传/下载文件,以及诸如提示正在运行的用户输入或中止执行的辅助功能。
典型用途包括创建一个包含一个或多个函数的 Python 模块,然后通过 fab 命令行工具执行它们。
Arc*_*ege 16
假设您无法安装 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"
Run Code Online (Sandbox Code Playgroud)
Ant*_*hon 12
我确实为此使用了GNU 并行,最具体地说,您可以使用以下方法:
parallel --tag --nonall --slf your.txt command
Run Code Online (Sandbox Code Playgroud)
随着your.txt
与所述服务器IP地址/名称的文件。
mic*_*has 11
非常基本的设置:
for host in $(cat hosts.txt); do ssh "$host" "$command" >"output.$host"; done
Run Code Online (Sandbox Code Playgroud)
使用名称/密码进行身份验证真的不是一个好主意。您应该为此设置一个私钥:
ssh-keygen && for host in $(cat hosts.txt); do ssh-copy-id $host; done
Run Code Online (Sandbox Code Playgroud)