使用pssh进行并行批量操作

简介:
假如同时给上千台服务器执行一个命令,拷贝一个文件,杀一个进程等,有什么简化运维管理的工具呢?在小型使用中我都是使用for循 环,数量巨大,一方面不确定操作是否成功,一方面for循环语句性能不好估计且是不是同步并行执行.,这类工具比如 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使用 (假设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

http://www.dongwm.com/archives/%E4%BD%BF%E7%94%A8pssh%E8%BF%9B%E8%A1%8C%E5%B9%B6%E8%A1%8C%E6%89%B9%E9%87%8F%E6%93%8D%E4%BD%9C/

本文转自 liang3391 51CTO博客,原文链接:http://blog.51cto.com/liang3391/732100

相关文章
|
8月前
LabVIEW异步调用VI的多个实例实现并行执行
LabVIEW异步调用VI的多个实例实现并行执行
205 1
|
5月前
|
分布式计算 并行计算 数据处理
|
SQL 关系型数据库 MySQL
MySQL备份策略——作业
MySQL备份策略——作业
|
SQL 存储 并行计算
openGauss并行查询测试(一)
openGauss并行查询测试
719 0
|
SQL
openGauss并行查询测试(二)
openGauss并行查询测试
955 0
|
存储 监控 安全
lsyncd 配合 rsync 实时差异同步节点文件
lsyncd 配合 rsync 实时差异同步节点文件
479 0
|
消息中间件 SQL NoSQL
只会单机执行定时任务?多机执行 yyds!
那我们是否有一种方法,可以让任务在多机同时执行,然后又可以避免多机同时处理相同数据的问题呢?这里给大家介绍一种多机分片的方式,也是最近在公司Get到的新技能。
146 0
|
分布式计算 Java 大数据
自适应查询执行AQE:在运行时加速SparkSQL
SPARK+AI SUMMIT 2020中文精华版线上峰会将会带领大家一起回顾2020年的SPARK又产生了怎样的最佳实践,技术上取得了哪些突破,以及周边的生态发展。本文是阿里巴巴云智能平台事业部王道远关于Spark3.0中自适应查询执行(AQE)的相关介绍。以下由Spark+AI Summit中文精华版峰会的精彩内容整理。
2646 0
自适应查询执行AQE:在运行时加速SparkSQL
|
SQL 测试技术
利用osql/ocmd批处理批量执行sql文件
原文:利用osql/ocmd批处理批量执行sql文件 上周在测试环境建了几十张表,保存了.sql文件,准备在正式环境重建的时候懒得一个个打开建了,做一在网上搜寻了一下,果然有简单点的方法。 利用osql/ocmd批处理批量执行sql文件 注意:在上图中我们可以看到osql 并不支持 SQL Server 2008的所有功能,如果需要使用SQL Server 2008的所有功能可以使用ocmd命令。
1015 0

热门文章

最新文章

下一篇
开通oss服务