原文:http://liang3391.blog.51cto.com/178205/732100
參考:http://www.ibm.com/developerworks/cn/aix/library/au-spunix_remoteserver/index.html
假如同時給上千台服務器執行一個命令,拷貝一個文件,殺一個進程等,有什么簡化運維管理的工具呢?在小型使用中我都是使用for循 環,數量巨大,一方面不確定操作是否成功,一方面for循環語句性能不好估計且是不是同步並行執行.,這類工具比如 pdsh,mussh,cssh,dsh等還有這里提到的pssh:
1 安裝:
1 安裝:
#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
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
[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 選項
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
[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
[ 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
[ 1 ] 15:05: 14 [SUCCESS ] 192.168.9.102 9922
[ 2 ] 15:05: 14 [SUCCESS ] 192.168.9.104 9922
