使用pssh进行并行批量操作
生活随笔
收集整理的這篇文章主要介紹了
使用pssh进行并行批量操作
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
假如同時給上千臺服務器執行一個命令,拷貝一個文件,殺一個進程等,有什么簡化運維管理的工具呢?在小型使用中我都是使用for循 環,數量巨大,一方面不確定操作是否成功,一方面for循環語句性能不好估計且是不是同步并行執行.,這類工具比如 pdsh,mussh,cssh,dsh等還有這里提到的pssh:pssh是一個簡單的字符界面并發向多個服務器發送指令進行執行的工具。適合一次性向集群大量服務器發送相同指令(并觀察輸出)
1. 安裝
a. 到google code找到最新的安裝包
http://code.google.com/p/parallel-ssh/downloads/list
Bash代碼??pssh是python寫的,因此下載之后解壓,安裝python安裝模塊的方式安裝
Bash代碼??2. 使用(假設已經做完ssh免登陸)
創建一個hosts.txt文件,將要遠程管理的機器加入
Bash代碼??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
轉載于:https://www.cnblogs.com/zhangmingcheng/p/7455092.html
總結
以上是生活随笔為你收集整理的使用pssh进行并行批量操作的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 小鹏P7汽车撞人致死!到底谁的错?
- 下一篇: LeetCode 153. Find M