之前遠程查看或傳輸文件都用ssh或rsync後來聽人介紹了pssh,從網上查到它是並行傳輸的,因此速度更快,使用python寫的。html
安裝完後會有5個命令python
用途linux
pssh 在多個主機上並行地運行命令。
pscp 把文件並行地複製到多個主機上。
prsync 經過 rsync 協議把文件高效地並行複製到多個主機上。
pslurp 把文件並行地從多個遠程主機複製到中心主機上。
pnuke 並行地在多個遠程主機上殺死進程。git
#yum -y install pythonvim
#-t 時間,默認60秒服務器
下面內容來自網絡網絡
2.配置密鑰,免密碼訪問管理機器
在使用以前須要配置密鑰訪問,以下:
#ssh-keygen #一直回車
#複製公鑰到遠端服務器
#ssh-copy-id -i .ssh/id_rsa.pub root@192.168.16.X
ps.若是端口不是默認22 ,須要使用:ssh-copy-id -i .ssh/id_rsa.pub 」-p 4567 yin@192.168.16.X」app
3:運行第一條命令,查看啓動時間ssh
]# pssh -h servers.txt -l root -P uptime
173.16.0.102: 13:14:57 up 1 day, 2:00, 1 user, load average: 0.00, 0.00, 0.00
173.16.0.100: 13:23:34 up 21:40, 1 user, load average: 0.00, 0.00, 0.00
[1] 13:13:52 [SUCCESS] 173.16.0.102
[2] 13:13:52 [SUCCESS] 173.16.0.100ide
4:刪除文件
我須要刪除之前yum.repo 文件
pssh -h servers.txt -P "rm -r /etc/yum.repos.d/*.repo"
5:傳輸單個文件
pscp -h servers.txt /etc/yum.repos.d/ftp.repo /etc/yum.repos.d/
6:運行yum update
]# pssh -h servers.txt -l root -P "yum update"
173.16.0.100: Loaded plugins: fastestmirror
173.16.0.102: Loaded plugins: fastestmirror
173.16.0.100: Loading mirror speeds from cached hostfile
173.16.0.102: Loading mirror speeds from cached hostfile
173.16.0.100: Setting up Update Process
173.16.0.102: Setting up Update Process
173.16.0.100: No Packages marked for Update
173.16.0.102: No Packages marked for Update
[1] 13:38:13 [SUCCESS] 173.16.0.100
[2] 13:38:13 [SUCCESS] 173.16.0.102
7:讓機器加載Ext4
]# pssh -h servers.txt -l root -P "modprobe ext4"
[1] 13:49:42 [SUCCESS] 173.16.0.100
[2] 13:49:42 [SUCCESS] 173.16.0.102
8:安裝e4fsprogs, 支持ext4分區
[root@gluster02b ~]# pssh -h servers.txt -l root -P "yum -y install e4fsprogs"
173.16.0.102: Loaded plugins: fastestmirror
173.16.0.100: Loaded plugins: fastestmirror
173.16.0.100: Complete!
[1] 13:53:11 [SUCCESS] 173.16.0.100
173.16.0.102:
Installed:
e4fsprogs.x86_64 0:1.41.12-2.el5
173.16.0.102: Complete!
[2] 13:53:11 [SUCCESS] 173.16.0.102
9:建立一個目錄
# pssh -h servers.txt -l root -P "mkdir /data01"
[1] 09:53:27 [SUCCESS] 173.16.0.100
[2] 09:53:27 [SUCCESS] 173.16.0.102
# pscp -h servers.txt /etc/fstab /etc/
[1] 09:53:51 [SUCCESS] 173.16.0.102
[2] 09:53:51 [SUCCESS] 173.16.0.100
10:複製文件夾到遠程
# pscp -h servers.txt -r /root/tools/ /root/
[1] 10:23:27 [SUCCESS] 173.16.0.100
[2] 10:23:28 [SUCCESS] 173.16.0.102
11:關閉Selinux
# pssh -h servers.txt -l root -P "sed -i '/SELINUX=enforcing/s/SELINUX=enforcing/SELINUX=disabled/' /etc/sysconfig/selinux"
[1] 11:47:15 [SUCCESS] 173.16.0.100
[2] 11:47:15 [SUCCESS] 173.16.0.102
# pssh -h servers.txt -l root -P init 6
[1] 11:47:28 [SUCCESS] 173.16.0.102
[2] 11:47:28 [SUCCESS] 173.16.0.100
# pssh -h servers.txt -l root -P sestatus
[1] 11:49:37 [FAILURE] 173.16.0.100 Exited with error code 255
[2] 11:49:37 [FAILURE] 173.16.0.102 Exited with error code 255
# pssh -h servers.txt -l root -P sestatus
173.16.0.100: SELinux status: disabled
[1] 11:52:32 [SUCCESS] 173.16.0.100
173.16.0.102: SELinux status: disabled
[2] 11:52:32 [SUCCESS] 173.16.0.102
http://sheriy.com/?p=748
http://www.theether.org/pssh/docs/0.2.3/pssh-HOWTO.html
== 簡介 ==
pssh是一個python編寫能夠在多臺服務器上執行命令的工具,同時支持拷貝文件,是同類工具中很出色的,相似pdsh,我的認爲相對pdsh更爲簡便,使用必須在各個服務器上配置好密鑰認證訪問。
項目地址:https://code.google.com/p/parallel-ssh/
PSSH provides parallel versions of OpenSSH and related tools. Included are pssh, pscp, prsync, pnuke, and pslurp. The project includes psshlib which can be used within custom applications. The source code is written in Python and can be cloned from:
git clone http://code.google.com/p/parallel-ssh/
PSSH is supported on Python 2.4 and greater (including Python 3.1 and greater). It was originally written and maintained by Brent N. Chun. Due to his busy schedule, Brent handed over maintenance to Andrew McNabb in October 2009.
== 下載安裝 ==
下載
wget http://parallel-ssh.googlecode.com/files/pssh-2.3.1.tar.gz
tar xf pssh-2.3.1.tar.gz
cd pssh-2.3.1/
python setup.py install
-l 遠程機器的用戶名
-P 執行時輸出執行信息
-p 一次最大容許多少鏈接pscp 傳輸文件到多個hosts,相似scp
pslurp 從多臺遠程機器拷貝文件到本地
pnuke 並行在遠程主機殺進程
prsync 使用rsync協議從本地計算機同步到遠程主機
== 實例 ==$ pssh -h ip.txt -l root chkconfig --level 2345 snmpd on
[1] 10:59:29 [SUCCESS] ... ...
[2] 10:59:29 [SUCCESS] ... ...
[3] 10:59:29 [SUCCESS] ... ...
... ...
$ pscp -h ip.txt -l root /etc/snmp/snmpd.conf /etc/snmp/snmpd.conf
[1] 11:00:42 [SUCCESS] ... ...
[2] 11:00:42 [SUCCESS] ... ...
[3] 11:00:42 [SUCCESS] ... ...
... ...
參考:http://my.oschina.net/guol/blog/59977
(一) 使用前提
中心主機鏈接遠程主機能夠經過ssh密鑰無密碼鏈接
(二) 命令格式
pssh 老是經過清單 文件指定主機
其中的每行採用 [user] host[:port] 形式。
(三) 建立servers.txt文件
文件的內容爲遠程主機的ip,和用於鏈接ssh的用戶名和端口
# vim /home/server.txt
192.168.0.177
(四) pssh用法-在多個主機上並行地運行命令
# pssh -P -h /home/server.txt hostname
在默認狀況下,每一個命令實例的輸出出如今 stdout 中。輸出劃分爲每一個主機一段。可是,能夠指定一個目錄來捕捉每一個實例的輸出。例如,若是運行前面的命令並添加 --outdir=/opt/output/,那麼會把每一個主機的命令輸出捕捉到/opt/output/ 中單獨的文件中
# pssh -P -h /home/server.txt --outdir=/opt/output/ hostname
# ll /opt/output/
# cat /opt/output/192.168.0.177
Standby
pssh能夠生成最多 32 個進程,並行地鏈接各個節點。若是遠程命令在 60 秒內沒有完成,鏈接會終止。若是命令須要更多處理時間,可使用 -t 設置更長的到期時間。(parallel-scp 和 parallel-rsync 沒有默認的到期時間,可是能夠用 -t 指定到期時間。)
(五) pscp用法-把文件或者目錄並行地複製到多個主機上
# pscp -h /home/server.txt /home/server.txt /opt /qubaoquan
其中/home/server.txt 爲本地目錄 /opt/qubaoquan爲文件名,即server.txt複製到遠端後重名爲qubaoquan,若是不指定遠端文件名只有目錄則保持原文件名
也能夠複製整個目錄到遠端
# ll /srv/test
# pscp --recursive -h /home/server.txt /srv/test /opt
(六) pslurp用法-把文件或者目錄並行地從多個遠程主機複製到中心主機上
它從每臺遠程計算機收集指定的文件,可是並不覆蓋文件的本地版本。pslurp 爲每臺遠程計算機建立一個子目錄並把指定的文件複製到此位置
# # pslurp --recursive -h /home/server.txt /etc/passwd /qubaoquan
/etc/passwd 爲遠程文件 /qubaoquan爲本地目錄,也能夠爲拷貝到本地後的文件名.
# tree /qubaoquan/
# pslurp --recursive -h /home/server.txt -L /srv/test/ /srv llll
其中 --recursive表示遞歸子目錄,-L 選項指定建立子目錄的位置,/srv爲遠程目錄,lll爲拷貝到本地後的目錄名,看目錄結構就知道了
#tree /srv/test/
(七) pnuke用法-並行地在多個遠程主機上殺死進程
pnuke 至關於運行 ssh host killall。pnuke 的參數是一個模式。在遠程計算機上運行的名稱符合這個模式的全部進程都被殺死。能夠用此命令方便地在一組服務器上中止同一守護進程。
# pnuke -h /home/server.txt --user=root cron
命令的結果則是在server.txt文件中指定的主機上執行killall cron命令 其中cron爲匹配到cron的進程,只要ps進程中出現相關詞語 都能殺死
192.168.12.4
vi host_list.txt
magic@shopex ~]$ pscp -h host_list.txt iptables /home/magic/.
[magic@shopex ~]$ pscp -h host_list.txt squid.conf /home/magic/.
[magic@shopex ~]$ pscp -h host_list.txt zabbix_agentd.conf /home/magic/.
[magic@shopex ~]$ pscp -h host_list.txt replace.sh /home/magic/.
[magic@shopex ~]$ pssh -x "-t -t" -h host_list.txt -P "/home/magic/squid.sh"
pscp -h host_list.txt crontab /home/magic/.
pscp -h host_list.txt crontab /root/.
pssh -h host_list.txt -P "crontab /root/crontab"
pssh -x "-t -t" -h host_list.txt -P "sudo crontab /home/magic/crontab"
pssh -x "-t -t" -h host_list.txt_bk -P "cp /home/magic/squid.conf /usr/local/squid-3.1.16/etc/."
pssh -x "-t -t" -h host_list.txt_bk -P "sudo /usr/local/squid-3.1.16/sbin/squid -k reconfigure"
pssh -x "-t -t" -h host_list.txt -P "cp /root/squid.conf /usr/local/squid-3.1.16/etc/."
pssh -x "-t -t" -h host_list.txt -P "/usr/local/squid-3.1.16/sbin/squid -k reconfigure"