PSSH介绍

pssh是一个python编写可以在多台服务器上执行命令的工具,同时支持拷贝文件,是同类工具中很出色的。它的用法可以媲美ansible的一些简单用法,执行起来速度比ansible快它支持文件并行复制,远程命令执行,杀掉远程主机上的进程等等。

安装PSSH

[root@CentOS]# yum install pssh #CentOS 直接yum安装
#pssh 安装需要python环境,centos都自带Python2.7环境,所以不用再次安装python

 [root@CentOS7-5 ~]# rpm -ql pssh  #以下几个是pssh安装包带有的 自动化工具
 /usr/bin/pnuke # 在远程多台主机上并行killall 指定进程
  /usr/bin/prsync #使用rsync协议将本地文件同步到远程多台主机上
  /usr/bin/pscp.pssh # 将本地主机文件复制到多台远程主机上
  /usr/bin/pslurp #将远程主机上相同文件路径复制到本地主机上
  /usr/bin/pssh #远程多台主机并行执行命令

1. PSSH使用

在使用pssh的命令时,首先要保证本地主机与远程主机可以进行密钥认证,或者批量的远程主机账号密码相同。密钥认证请查看安全加密一章

pssh命令
  --verison :查看版本
  -h :主机文件列表,指定一个文件,文件内容为 主机的, 用户、 IP、端口 ,内容格式为 [user@]host[:port]
  -H:直接指定单台主机,内容格式 [user@]host[:port]
  -l :登陆使用的用户名
  -p:并发的线程数
  -o:输出的文件目录
  -e:错误输入的文件
  -t:TIMEOUT 超时时间设置,0无限制
  -O:SSH的选项
  -v:详细模式
  -A:手动出入密码模式
  -x:额外的命令行参数使用空白符,引号,反斜线处理
  -X:额外的命令行参数,单个参数模式,同-x
  -i:每个服务器内部处理信息输出
  -P:打印服务器返回信息

·pssh实例

通过pssh批量关闭seLinux
pssh -H root@192.168.1.100 -i "sed -i "s@SELINUX=enforcing@SELINUX=disabled@" /etc/selinux/config"
pssh -H root@192.168.1.100 -i setenforce 0 通过pssh批量修改网卡名字
pssh -H root@192.168.1.100 -i "sed -i 's@GRUB_CMDLINE_LINUX="rhgb quiet"@GRUB_CMDLINE_LINUX="rhgb quiet net.ifnames=0" /etc/default/grub'
pssh -H root@192.168.1.100 -i "grub2-mkconfig -o /etc/grub2.cfg"
pssh -H root@192.168.1.100 -i reboot 将标准错误和标准正确重定向保存到指定目录文件
pssh -H 192.168.1.100 -o /log -e /log/error.log -i hostname

2. PSCP.PSSH使用

pscp.pssh功能是将本地文件批量复制到远程主机

pscp 命令
-v:显示复制过程
-a:复制过程中保留常规属性
-r:递归复制目录
-h:host files
-H: user@host:port
-l: user
-p: 同上
-o: outdir
-e:error dir
-t:timeout
-r:递归复制目录下所有文件
与pssh命令的option 功能基本一样

·pscp实例

将本地test.sh 复制到/app/目录
pscp.pssh -H 192.168.1.100 /root/test/test.sh /app/
pscp.pssh -h host.txt /root/test/test.sh /app/ 将本地多个文件批量复制到/app/目录
pscp.pssh -H 192.168.1.100 /root/f1.sh /root/f2.sh /app/ 将本地目录批量复制到/app/目录
pscp.pssh -H 192.168.1.100 -r /root/test/ /app/

3. pslurp.pssh使用

pslurp.pssh功能是将远程主机的文件批量复制到本地

pslurp 命令
# 这些选项同pscp命令的功能一样pslurp -vAr -h -H -l -p -o -e -t -O -x -X
-L:指定从远程主机下载到本机的存储的目录, pslurp 172.16.1.100 -L /data/pssh sourceFile localFileName

·pslurp实例

批量下载目标服务器的passwd文件至/data下,并更名为pass
pslurp -H 192.168.1.10 -L /data/ /etc/passwd pass

4. prsync使用

将本地的/etc/sysconfig目录递归同步到目标服务器的 /tmp/目录下,并保持原来的时间戳,使用用户 root
prsync -h host.txt -l root -a -r /etc/sysconfig /tmp/

5. pnuke使用

杀死目标服务器的syslog进程
pnuke -h host.txt syslog

自动化运维工具——pssh的更多相关文章

  1. 小型自动化运维工具pssh和传输工具rsync

    一.简单介绍 1.pssh全称是parallel-ssh,基于Python编写的并发在多台服务器上批量执行命令的工具.包括pssh,pscp,prsync,pnuke和pslurp.该项目包括pssh ...

  2. 自动化运维工具-pssh工具安装配置及简单使用讲解

    1.先决条件:安装pssh工具要求python版本大于2.4即可. 安装pssh工具的主机针对远程主机需要配置免秘钥认证: ssh-keygen -t rsa ssh-copy-id [remoteh ...

  3. 自动化运维工具pssh、pdsh、pscp

    pssh命令是一个python编写可以在多台服务器上执行命令的工具,同时支持拷贝文件,是同类工具中很出色的,类似pdsh,个人认为相对pdsh更为简便,使用必须在各个服务器上配置好密钥认证访问. 以下 ...

  4. CheungSSH国产自动化运维工具开源Web界面

    CheungSSH web2.0 发布文档 CheungSSH 简介 CheungSSH是一款国人自主研发的Linux运维自动化管理服务器软件,秉着为企业降低运营成本,解放管理员双手和自动化生产的理念 ...

  5. 自动化运维工具Ansible详细部署 (转载)

    自动化运维工具Ansible详细部署 标签:ansible 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://sofar.blog. ...

  6. 自动化运维工具之 Ansible 介绍及安装使用

    一.初识Ansible 介绍: Absible 使用 模块(Modules)来定义配置任务.模块可以用标准脚本语言(Python,Bash,Ruby,等等)编写,这是一个很好的做法,使每个模块幂等.A ...

  7. 自动化运维工具之ansible

    自动化运维工具之ansible   一,ansible简介 ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet.cfengine.chef.func.fab ...

  8. 自动化运维工具Ansible详细部署 - 人生理想在于坚持不懈 - 51CTO技术博客

    自动化运维工具Ansible详细部署 - 人生理想在于坚持不懈 - 51CTO技术博客 自动化运维工具Ansible详细部署

  9. 用自动化运维工具解放IT运维

    何谓自动化运维,即在最少的人工干预下,结合运用脚本与第三方工具,保证业务系统7*24小时高效稳定运行.这应该是所有业务系统运维终极目标. 我们对运维的要求通常是: 1.事前预警 在故障出现之前,管理人 ...

随机推荐

  1. Node.js 第三方包的安装、升级、卸载,以及包依赖管理

    本地安装: npm install package-name 全局全装: npm install -g  package-name 举个栗子 全局安装 React项目的脚手架 npm install ...

  2. Eclipse Photon 小技巧(tips)

    本文内容: Eclipse 4.8版本 代号 photon  光量子 ,感觉更像ide了,虽然这些技巧广为认知,但是作为eclipse来说,也是很重要的. Code completion allows ...

  3. Js 验证时间格式是否正确

    function RQcheck(RQ) { var date = RQ; //(-|\/)分隔符 var result = date.match(/^(\d{1,4})(-|\/)(\d{1,2}) ...

  4. 转 AIX filesystemcache引发的Oracle事故

    http://blog.itpub.net/26015009/viewspace-1806629/

  5. HTTP1.1中CHUNKED编码解析(转载)

    HTTP1.1中CHUNKED编码解析 一般HTTP通信时,会使用Content-Length头信息性来通知用户代理(通常意义上是浏览器)服务器发送的文档内容长度,该头信息定义于HTTP1.0协议RF ...

  6. Redis、Memcache区别

    Redis.Memcache区别 redis单核 memcahce多核 redis支持数据持久化 redis支持的数据类型比较多 memcache 只有key->value类型 key-> ...

  7. (转载)Newtonsoft.Json使用总结

    Newtonsoft.Json使用总结 初识JSON.......................................................................... ...

  8. userBean-作用范围session

    package com.java1234.model; public class Student { private String name;private int age; public Strin ...

  9. HDU Rabbit and Grass 兔子和草 (Nim博弈)

    思路:简单Nim博弈,只需要将所给的数字全部进行异或,结果为0,则先手必败.否则必胜. #include <iostream> using namespace std; int main( ...

  10. Bot Framework:Activity类简明指南

    Bot Framework相关文档:https://docs.botframework.com/en-us/csharp/builder/sdkreference/attachments.html B ...