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. java模拟多线程

    public class HTTPRequest  implements Runnable { public void run() { //这里实现发送请求 } public static void ...

  2. nginx配置SSL证书实现https服务

    在前面一篇文章中,使用openssl生成了免费证书 后,我们现在使用该证书来实现我们本地node服务的https服务需求.假如我现在node基本架构如下: |----项目 | |--- static ...

  3. 常用API(Object、String、StringBuffer、用户登陆注册)

    常用API 今日内容介绍 u Object u String u StringBuilder 第1章 Java的API及Object类 在以前的学习过程中,我们都在学习对象基本特征.对象的使用以及对象 ...

  4. zuul的本地跳转

  5. so文件动态加载注意事项

    动态加载是指将so文件存放于服务器,在需要用的时候,通过服务器下载到本地,然后加载. 需要注意的: 手机cpu架构,不同的架构运行不同的so 解决方法: 1,欺骗性: 如果so架构不全,就在apk打包 ...

  6. 关于纠正《Hive权威指南》中的结论~“hive在使用set自定义变量时,hivevar命名空间是可选的”~的论证

    背景: 根据<Hive权威指南>上讲,在hive-0.8.0以后可以使用--define key=value命令定义用户自定义的变量以便在Hive脚本中引用.当用户使用这个功能时,Hive ...

  7. LR脚本中常用函数使用介绍

    1.变量和参数的设置 //将IP地址和端口放入到参数中lr_save_string("192.168.1.133:8081","ip"); //计算变量数组的元 ...

  8. javascript 和Jquery 互转

    jQuery对象转成DOM对象: 两种转换方式将一个jQuery对象转换成DOM对象:[index]和.get(index); (1)jQuery对象是一个数据对象,可以通过[index]的方法,来得 ...

  9. 【LeetCode】2.Add Two Numbers 链表数相加

    题目: You are given two linked lists representing two non-negative numbers. The digits are stored in r ...

  10. 2017.10.3 QBXT 模拟赛

    题目链接 T1 模拟 #include <cstring> #include <cstdio> #define N 105000 int L,R; char s[N]; int ...