Linux运维并行批量操作命令pssh的使用
假如同時(shí)給上千臺(tái)服務(wù)器執(zhí)行一個(gè)命令,拷貝一個(gè)文件,殺一個(gè)進(jìn)程等,有什么簡化運(yùn)維管理的工具呢?在小型使用中我都是使用for循 環(huán),數(shù)量巨大,一方面不確定操作是否成功,一方面for循環(huán)語句性能不好估計(jì)且是不是同步并行執(zhí)行.,這類工具比如 pdsh,mussh,cssh,dsh等還有這里提到的pssh:
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
2? pssh使用 (假設(shè)ssh已做好SSH信任,ssh信任請(qǐng)參看:關(guān)于ssh命令研究以及SSH信任詳解)
pssh工具包主要有5個(gè)程序:
1 pssh? 多主機(jī)并行運(yùn)行命令
[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???//注意我的端口號(hào)不僅是默認(rèn)的22
假如想將輸出重定向到一個(gè)文件 加-o?file?選項(xiàng)
2 pscp? 把文件并行地復(fù)制到多個(gè)主機(jī)上
注意 是從服務(wù)器端給客戶端傳送文件:
[root@server pssh-2.2.2]# pscp -h test.txt /etc/sysconfig/network /tmp/network?? //標(biāo)示將本地的/etc/sysconfig/network傳到目標(biāo)服務(wù)器的/tmp/network
3 prsync 使用rsync協(xié)議從本地計(jì)算機(jī)同步到遠(yuǎn)程主機(jī)
[root@server ~]# pssh -h test.txt -P mkdir /tmp/etc
[root@server ~]# prsync -h test.txt -l dongwm -a -r /etc/sysconfig /tmp/etc //標(biāo)示將本地的/etc/sysconfig目錄遞歸同步到目標(biāo)服務(wù)器的 /tmp/etc目錄下,并保持原來的時(shí)間戳,使用用戶 dongwm
4? pslurp 將文件從遠(yuǎn)程主機(jī)復(fù)制到本地,和pscp方向相反:
[root@server ~]# pslurp -h test.txt?? -L /tmp/test -l root /tmp/network test? //標(biāo)示將目標(biāo)服務(wù)器的/tmp/network文件復(fù)制到本地的/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/
總計(jì) 4.0K
-rw-r--r--?1 root root 60 2011-04-22 14:53?test
[root@server ~]# ll /tmp/test/192.168.9.104/
總計(jì) 4.0K
-rw-r--r--?1 root root 60 2011-04-22 14:53?test
5? pnuke 并行在遠(yuǎn)程主機(jī)殺進(jìn)程:
[root@server ~]# pnuke -h test.txt?? syslog //殺死目標(biāo)服務(wù)器的syslog進(jìn)程,只要ps進(jìn)程中出現(xiàn)相關(guān)詞語 都能殺死
[1]?15:05:14?[SUCCESS]?192.168.9.102?9922
[2]?15:05:14?[SUCCESS]?192.168.9.104?9922
轉(zhuǎn)載于:https://blog.51cto.com/stoneking/1962882
總結(jié)
以上是生活随笔為你收集整理的Linux运维并行批量操作命令pssh的使用的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【iOS-Cocos2d游戏开发】系列(
- 下一篇: java面向对象(二)之继承