`

pssh 工具

阅读更多

1Linux系统

 

管理上千服务器而且要并发执行要么字写工具用开源的也不错,

这类工具比如 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

 

 

pssh   多主机并行运行命令

pscp   传输文件到多个hosts,他的特性和scp差不多

pslurp   从多台远程机器拷贝文件

pnuke    kill远程机器的进程

pslurp   从远程主机考本文件到本地

prsync   使用rsync协议从本地计算机同步到远程主机

 

pssh:

-h 执行命令的远程主机列表  或者 -H user@ip:port  文件内容格式[user@]host[:port]

-l 远程机器的用户名

-p 一次最大允许多少连接

-o 输出内容重定向到一个文件

-e 执行错误重定向到一个文件

-t 设置命令执行的超时时间

-A 提示输入密码并且把密码传递给ssh

-O 设置ssh参数的具体配置,参照ssh_config配置文件

-x 传递多个SSH 命令,多个命令用空格分开,用引号括起来

-X 同-x 但是一次只能传递一个命令

-i 显示标准输出和标准错误在每台host执行完毕后

-I 读取每个输入命令,并传递给ssh进程 允许命令脚本传送到标准输入

-P 打印输出


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

 

2 Window系统

pscp和scp功能相同,但pscp同时支持windows下使用,它有效解决了windows系统向linux服务器传输文件,而且它只有一个文件,即pscp.exe,建议将该文件放到C:\WINDOWS\system32下面,这样就可以在任何地方调用该文件命令,你也可以放在任意你指定文件夹下。

 

pscp语法基本与scp相同,但也有一下几个注意点:

-p 拷贝文件的时候保留源文件建立的时间。
-q 执行文件拷贝时,不显示任何提示消息。
-r 拷贝整个目录
-v 拷贝文件时,显示提示信息。

 

Usage:
  pscp [options] [user@]host:source target
  pscp [options] source [source...] [user@]host
  pscp [options] -ls user@host:filespec


  用法:
  pscp [选项] [用户名@]主机:源文件 目标文件
  pscp [选项] 源文件 [源文件……] [用户名@]主机
  pscp [选项] -ls 用户名@主机:文件空间?


  Options:
  选项:
  -p preserve file attributes 保护文件属性
  -q quiet, don't show statistics 安静,不显示统计
  -r copy directories recursively 复制子文件夹
  -V print version information and exit 显示信息
  -v show verbose messages
  -load sessname Load settings from saved session
  -load 加载,加载保存节的设定
  -P port connect to specified port
  -P 端口,连接到指定空间端口
  -l user connect with specified username
  -l 用户,用指定的用户连接空间
  -pw passw login with specified password
  -pw 密码,用指定的密码登录空间
  -1/-2 强迫 ssh 使用的版本
  -4 -6 force use of IPv4 or IPv6
  -C 打开压缩
  -i key 钥匙,证明用的钥匙文件
  -batch 关闭交互能力,也许
  -unsafe 不安全,允许伺服端取代字符 (危险的)

 

例子:

假设需要从ftp上抽取opt目录下所有名字为log_2*.zip的压缩文件到本地D:\local\zip,然后解压到D:\local\unzip文件夹下。

需要工具:putty, pscp.exe, 7-zip

putty目录:D:\putty_path\putty

7-zip目录:C:\Program Files\7-Zip

 

脚本如下:

D: 
cd D:\putty_path\putty
pscp -pw password username@server:/opt/*/log_2*.zip D:\local\zip
C:
cd C:\Program Files\7-Zip
7z x "D:\local\zip\*.zip" -aoa -o "D:\local\unzip"

 

其中server为ftp服务器名,username为登陆ftp的用户名,password为登陆ftp的密码。

 

 

http://312461613.blog.51cto.com/965442/1686599/

http://blog.csdn.net/qzlmhy/article/details/22403603

分享到:
评论

相关推荐

    linux轻量级pssh工具

    pssh是python写的可以并发在多台机器上批量执行命令的工具,它的用法可以媲美ansible的一些简单用法,执行起来速度比ansible快它支持文件并行复制,远程命令执行,杀掉远程主机上的进程等等。杀手锏是文件并行复制,...

    pssh source

    cd pssh/ python setup.py install * 功能 + parallel-ssh (pssh) 在多个主机上并行地运行命令。 + parallel-scp (pscp)把文件并行地复制到多个主机上。 + parallel-rsync (psync)通过 rsync 协议把文件...

    通过pssh和sshpass工具实现一对多的免密登陆+批量操作

    pssh(yum install pssh安装):用于批量执行操作,前提是已经配置好了ssh免密登录 sshpass(yum install sshpass安装):用于ssh登陆时自动输入密码 思路: 服务器A上生成公钥,将公钥分发给所有SUT的test用户,...

    pssh批量管理

    【pssh批量管理】是一种基于Python编写的高效Linux系统批量管理工具,它的全称为"Parallel SSH"。这个软件设计的主要目标是使得系统管理员能够同时在多台远程主机上执行命令,极大地提高了工作效率。pssh利用SSH协议...

    pssh-2.3.1.zip

    PSSH提供OpenSSH和相关工具的并行版本。包括pssh,pscp,prsync,pnuke和pslurp。该项目包括psshlib,可以在自定义应用程序中使用。 pssh是python编写,可以并发在多台机器上批量执行命令的工具,用法可以媲美...

    pssh使用文档

    pssh(Parallel SSH)是一个高效且便捷的工具,用于在多个远程服务器上并发执行相同的命令。它特别适用于集群环境中的大规模操作,例如部署更新、监控系统状态等场景。通过pssh,用户可以简化对多台服务器的管理流程...

    pssh-2.3.1.tar.gz

    为了提高效率,运维人员通常需要寻找能够批量执行命令、传输文件的工具,而PSSH(Parallel SSH)正是这样一个强大的工具。PSSH 2.3.1版本的发布,为Linux运维带来了更多便利。 PSSH,全称为Parallel SSH,顾名思义...

    centos6.5配置ssh免秘钥登陆执行pssh命令的讲解

    首先,我们需要检查并安装pssh工具。`pssh`全称为Parallel SSH,它允许你并行地在多台主机上执行SSH命令,大大提高了运维效率。在CentOS 6.5上,可以通过`yum`包管理器来安装pssh: ```bash yum list pssh ``` ...

    mussh-pssh合集.rar

    为了解决这个问题,出现了如mussh和pssh这样的并行SSH工具,它们能够同时对多台服务器执行命令,显著提高了运维人员的工作效率。 首先,让我们了解一下mussh。mussh是一个基于Perl编写的命令行工具,它扩展了SSH的...

    数据中心故障与事故原因分析.docx

    在实际案例中,如文中提到的支付宝和携程的故障,可能是由于运维人员在批量操作时的误操作,如使用pssh工具执行修复漏洞脚本时的错误指令,导致了全局性的数据删除。虽然这种错误是人为的,但通常会留下操作记录,...

    pssh安装文档1

    `pssh`(Parallel SSH)是一个非常有用的工具,它允许管理员对多台远程主机进行并行命令执行,大大简化了集群维护和管理的工作。本文档将详细介绍如何在Spark主节点上安装和配置`pssh`。 首先,`pssh`主要适用于对...

    pssh远程套件工具配置.doc

    准备实验所需的虚拟机环境,实验环境所需要的主机及对应的IP设置列表,正确配置IP地址、主机名称,并且为每台主机配置YUM 源。

    pssh:并行SSH工具

    PSSH提供了并行版本的OpenSSH和相关工具,包括pssh,pscp,prsync,pnuke和pslurp。 该项目包括psshlib,可在自定义应用程序中使用。 源代码是用Python编写的。 在Python 3.5及更高版本中支持PSSH的此派生。 它最初...

    bloomer:用Go语言编写的类似于pssh的工具

    盛开 ``` bloom bloom is a command-line tool for executing tasks on groups of servers. Usage: bloom [options] <task> Options: -f --file BLOOMFILE Path to bloom.toml config file ...

    pssh-writeup

    标题 "pssh-writeup" 暗示我们讨论的主题是关于 "pssh",这是一个用于并行执行命令在多台远程主机上的工具。在Linux和Unix环境中,这通常用于系统管理任务,例如批量更新、配置检查或性能测试。让我们深入探讨一下`...

    parallel-ssh:PSSH提供了并行版本的OpenSSH和相关工具

    SSH上的任意命令( pssh实用程序) 通过SSH(分别为pscp和pslurp实用程序)将文件复制到远程服务器或从远程服务器复制文件 通过SSH同步文件( prsync实用程序) 通过SSH pnuke终止进程( pnuke实用程序) 该项目...

    jBPM4.4Pssh.rar_jbpm-4.4_ssh jbpm_工作流OA

    在本压缩包 "jBPM4.4Pssh.rar" 中,重点是将 jbPM 4.4 与 SSH(Struts、Spring 和 Hibernate)框架整合的示例。SSH 是 Java Web 开发中常见的三大框架,它们分别负责视图层、业务层和数据持久层的管理。 Struts 是...

    企业Linux运维自动化实战视频.zip

    9PSSH企业实战批量工具.mp4 10PSSH企业实战批量工具.mp4 11Ansible自动化运维工具实战.mp4 12Ansible自动化运维工具实战.mp4 13Ansible自动化运维工具实战.mp4 14Ansible自动化运维工具实战.mp4 15Ansible自动化运维...

    Puppet给运维带来的变革

    在这场变革中,Puppet作为一种强大的自动化配置管理工具,扮演了举足轻重的角色。本文旨在深入探讨Puppet如何改变传统的运维方式,并通过其核心特性与应用场景来展示它在现代IT环境中的价值。 #### 关于Puppet ...

Global site tag (gtag.js) - Google Analytics