pssh 批量管理工具使用方法

管理上千服務器並且要併發執行要麼字寫工具用開源的也不錯,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.100.040.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

相關文章
相關標籤/搜索