使用pssh批量管理服务器

简介: pssh是一个可以在多台服务器上执行命令的工具,同时支持拷贝文件,是同类工具中很出色的。使用是必须在各个服务器上配置好密钥认证访问。

pssh是一个可以在多台服务器上执行命令的工具,同时支持拷贝文件,是同类工具中很出色的。使用是必须在各个服务器上配置好密钥认证访问。

在系统centos 5.6  64位 和 red hat enterprise linux 6.1 64位中测试通过

1   安装pssh

    在http://www.theether.org/pssh/  或者http://code.google.com/p/parallel-ssh/下载pssh最新版本

    #   wget  http://www.theether.org/pssh/pssh-1.4.3.tar.gz

    #   tar zxvf pssh-1.4.3.tar.gz

   #   cd pssh-1.4.3

  #   wget 'http://peak.telecommunity.com/dist/ez_setup.py'

  #   python ez_setup.py

 #  python setup.py install

2    pssh使用

   

[html]  view plain copy print ?
  1. Usage: pssh [OPTIONS] -h hosts.txt prog [arg0] ..  
  2.   
  3.   -h --hosts   hosts file (each line "host[:port] [user]")  
  4.   -l --user    username (OPTIONAL)  
  5.   -p --par     max number of parallel threads (OPTIONAL)  
  6.   -o --outdir  output directory for stdout files (OPTIONAL)  
  7.   -e --errdir  output directory for stderr files (OPTIONAL)  
  8.   -t --timeout timeout (secs) (-1 = no timeout) per host (OPTIONAL)  
  9.   -O --options SSH options (OPTIONAL)  
  10.   -v --verbose turn on warning and diagnostic messages (OPTIONAL)  
  11.   -P --print   print output as we get it (OPTIONAL)  
  12.   -i --inline  inline aggregated output for each server (OPTIONAL)  
  13.   
  14. Example: pssh -h nodes.txt -l irb2 -o /tmp/foo uptime  

创建管理服务器列表文件

vi  server1.txt

192.168.1.11

192.168.1.12

192.168.1.13

192.168.1.14

在各个主机执行命令hostname

   # pssh -h server1.txt -l root -P hostname

在各个主机传送文件

   pscp -h server1.txt -l root test.txt /tmp/test.txt

   prsync -r -h server1.txt -l root  foo /home/irb2/foo

把文件或者目录并行地从多个远程主机复制到中心主机

它从每台远程计算机收集指定的文件,但是并不覆盖文件的本地版本。pslurp 为每台远程计算机创建一个子目录并把指定的文件复制到此位置

# pslurp -r -h /home/server1.txt  /home/test.txt  /home

/home/server1.txt  为远程文件 /home为本地目录,也可以为拷贝到本地后的文件名

# pslurp -r -h /home/server1.txt -L /srv/test/ /srv llll

其中 -r表示递归子目录,-L 选项指定创建子目录的位置,/srv为远程目录,lll为拷贝到本地后的目录名

 pnuke用法-并行地在多个远程主机上杀死进程

pnuke 相当于运行 ssh host killall。pnuke 的参数是一个模式。在远程计算机上运行的名称符合这个模式的所有进程都被杀死。可以用此命令方便地在一组服务器上停止同一守护进程。

# pnuke -h /home/server.txt --user=root cron

命令的结果则是在server.txt文件中指定的主机上执行killall cron命令 其中cron为匹配到cron的进程, 只要ps进程中出现相关词语 都能杀死


假如同时给上千台服务器执行一个命令,拷贝一个文件,杀一个进程等,有什么简化运维管理的工具呢?在小型使用中我都是使用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信任请参看:
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


目录
相关文章
|
7月前
|
弹性计算 运维 监控
ECS监控与管理
ECS监控与管理
100 5
|
7月前
|
弹性计算 Linux 网络安全
连接并管理ECS
连接并管理ECS
107 4
|
7月前
|
弹性计算 网络安全
阿里云OpenAPI提供了多种接口来管理ECS实例
【1月更文挑战第8天】【1月更文挑战第36篇】阿里云OpenAPI提供了多种接口来管理ECS实例
272 1
|
7月前
|
弹性计算 Linux 数据安全/隐私保护
在已有的 ECS 上重装幻兽帕鲁服务器、迁移到计算巢、或升级计算巢服务版本
现在你可以参考这篇教程,将原来搭建的幻兽帕鲁服务器迁移到计算巢上,享受计算巢上所支持的界面化调整游戏配置(死亡掉落、服务器密码等)。 或者也可以用于重新安装,升级到最新版本的计算巢幻兽帕鲁服务。
31395 8
|
5月前
|
存储 弹性计算 运维
可观测性体系问题之ECS管控对其所有日志的管理如何解决
可观测性体系问题之ECS管控对其所有日志的管理如何解决
49 0
|
6月前
|
监控 安全 Linux
Linux服务器如何管理sshd的连接
【6月更文挑战第6天】Linux服务器如何管理sshd的连接
50 4
|
6月前
|
弹性计算 安全 网络安全
带你读《从基础到应用云上安全航行指南》——干货长文快收藏!阿里云专家教你如何安全访问和管理ECS资源(3)
**《从基础到应用云上安全航行指南》——阿里云专家教你如何安全访问和管理ECS资源(3)** 在阿里云的广阔云海中,ECS(弹性计算服务)资源如同航行的船只,承载着我们的业务与数据。如何确保这些
|
7月前
|
存储 安全 网络协议
服务器故障与管理口与raid
服务器故障与管理口与raid
|
7月前
|
弹性计算 Kubernetes 监控
【阿里云弹性计算】阿里云 ECS 与 Kubernetes 集成:轻松管理容器化应用
【5月更文挑战第28天】阿里云ECS与Kubernetes集成,打造强大容器管理平台,简化应用部署,实现弹性扩展和高效资源管理。通过Kubernetes声明式配置在ECS上快速部署,适用于微服务和大规模Web应用。结合监控服务确保安全与性能,未来将深化集成,满足更多业务需求,引领容器化应用管理新趋势。
272 2
|
6月前
|
存储 算法 搜索推荐
Cloudstack多个管理服务器节点
Cloudstack多个管理服务器节点
下一篇
DataWorks