pssh
(Parallel SSH)是一个用于在多台远程Linux服务器上并行执行命令的工具
安装pssh
:
对于Debian/Ubuntu系统,使用以下命令安装:
sudo apt-get install pssh
对于RHEL/CentOS系统,使用以下命令安装:
sudo yum install pssh
创建一个包含目标服务器列表的文件。每个服务器一行,格式为[user@]host[:port]
。例如,创建一个名为servers.txt
的文件,内容如下:
user1@server1.example.com
user2@server2.example.com:2222
server3.example.com
使用pssh
执行命令。以下是一些常用的pssh
选项:
-h
:指定包含服务器列表的文件。-l
:指定SSH登录用户名(如果未在服务器列表文件中指定)。-p
:设置并行进程数(默认为32)。-t
:设置SSH连接超时(以秒为单位,默认为0)。-o
:指定输出文件目录。-e
:指定错误输出文件目录。-A
:启用密码认证(不推荐,因为安全性较低)。-i
:忽略错误(继续执行其他服务器上的命令)。-O
:设置SSH选项(例如,禁用HostKey检查:-O StrictHostKeyChecking=no
)。示例命令:
pssh -h servers.txt -l myuser -p 10 -t 60 "df -h"
这将在servers.txt
中列出的服务器上并行执行df -h
命令,使用myuser
作为SSH登录用户名,最多有10个并行进程,SSH连接超时为60秒。
注意:为了避免在执行命令时输入密码,建议使用SSH密钥对进行身份验证。在所有目标服务器上将公钥添加到~/.ssh/authorized_keys
文件中,并确保私钥在本地可用。