管理上千服務器並且要併發執行要麼字寫工具用開源的也不錯,css
這類工具好比 pdsh,mussh,cssh,dsh等還有這裏提到的pssh:
1 安裝:python
#wget http://peak.telecommunity.com/dist/ez_setup.py
python ez_setup.py
#wget http://parallel-ssh.googlecode.com/files/pssh-2.2.2.tar.gz
# tar zxvf pssh-2.2.2.tar.gz
# cd pssh-2.2.2
# python setup.py install服務器
pssh 多主機並行運行命令併發
pscp 傳輸文件到多個hosts,他的特性和scp差很少ssh
pslurp 從多臺遠程機器拷貝文件ide
pnuke kill遠程機器的進程工具
pslurp 從遠程主機考本文件到本地google
prsync 使用rsync協議從本地計算機同步到遠程主機spa
pssh:code
-h 執行命令的遠程主機列表 或者 -H user@ip:port 文件內容格式[user@]host[:port]
-l 遠程機器的用戶名
-p 一次最大容許多少鏈接
-o 輸出內容重定向到一個文件
-e 執行錯誤重定向到一個文件
-t 設置命令執行的超時時間
-A 提示輸入密碼而且把密碼傳遞給ssh
-O 設置ssh參數的具體配置,參照ssh_config配置文件
-x 傳遞多個SSH 命令,多個命令用空格分開,用引號括起來
-X 同-x 可是一次只能傳遞一個命令
-i 顯示標準輸出和標準錯誤在每臺host執行完畢後
-I 讀取每一個輸入命令,並傳遞給ssh進程 容許命令腳本傳送到標準輸入
-P 打印輸出
2 pssh使用 (假設ssh已作好SSH信任,ssh信任請參看:關於ssh命令研究以及SSH信任詳解)
pssh工具包主要有5個程序:
1 pssh 多主機並行運行命令
[root@server pssh-2.2.2]# pssh -P -h test.txt uptime
192.168.9.102: 14:04:58 up 26 days, 17:05, 0 users, load average: 0.07, 0.02, 0.00
192.168.9.102: [1] 14:04:58 [SUCCESS] 192.168.9.102 9922
192.168.8.171: 14:04:59 up 35 days, 2:01, 6 users, load average: 0.00, 0.00, 0.00
192.168.8.171: [2] 14:04:59 [SUCCESS] 192.168.8.171 22
192.168.9.104: 14:04:59 up 7 days, 20:59, 0 users, load average: 0.10, 0.04, 0.01
192.168.9.104: [3] 14:04:59 [SUCCESS] 192.168.9.104 9922
[root@server pssh-2.2.2]# cat test.txt
192.168.9.102:9922
192.168.9.104:9922
192.168.8.171:22 //注意個人端口號不只是默認的22
假如想將輸出重定向到一個文件 加-o file 選項
2 pscp 把文件並行地複製到多個主機上
注意 是從服務器端給客戶端傳送文件:
[root@server pssh-2.2.2]# pscp -h test.txt /etc/sysconfig/network /tmp/network //標示將本地的/etc/sysconfig/network傳到目標服務器的/tmp/network
3 prsync 使用rsync協議從本地計算機同步到遠程主機
[root@server ~]# pssh -h test.txt -P mkdir /tmp/etc
[root@server ~]# prsync -h test.txt -l dongwm -a -r /etc/sysconfig /tmp/etc //標示將本地的/etc/sysconfig目錄遞歸同步到目標服務器的 /tmp/etc目錄下,並保持原來的時間戳,使用用戶 dongwm
4 pslurp 將文件從遠程主機複製到本地,和pscp方向相反:
[root@server ~]# pslurp -h test.txt -L /tmp/test -l root /tmp/network test //標示將目標服務器的/tmp/network文件複製到本地的/tmp/test目錄下,並改名爲test
[1] 14:53:54 [SUCCESS] 192.168.9.102 9922
[2] 14:53:54 [SUCCESS] 192.168.9.104 9922
[root@server ~]# ll /tmp/test/192.168.9.10
192.168.9.102/ 192.168.9.104/
[root@server ~]# ll /tmp/test/192.168.9.102/
總計 4.0K
-rw-r--r-- 1 root root 60 2011-04-22 14:53 test
[root@server ~]# ll /tmp/test/192.168.9.104/
總計 4.0K
-rw-r--r-- 1 root root 60 2011-04-22 14:53 test
5 pnuke 並行在遠程主機殺進程:
[root@server ~]# pnuke -h test.txt syslog //殺死目標服務器的syslog進程,只要ps進程中出現相關詞語 都能殺死
[1] 15:05:14 [SUCCESS] 192.168.9.102 9922
[2] 15:05:14 [SUCCESS] 192.168.9.104 9922