pssh,pscp,pslurp使用实践[通俗易懂]

pssh,pscp,pslurp使用实践

大家好,又见面了,我是全栈君。

    因为常常须要到几十台机器上运行同样的命令,而眼下机器上还没有部署Saltstack或Puppet等集群化管理工具. 因为每台server上都使用同样的公钥,故之前都是写一些脚本:把IP 放到一个文件里,再依次从文件里读取一个IP ,通过SSH用密钥登录到目标机器上运行命令.刚開始使用的时候,认为还能够接受,至少比手动登录到每一台机机器上要省时省力.可是,后面发现有的机器SSH连接比較慢,须要等一会儿,因为是顺序的单进程运行,所以认为有点慢,想要更快一点. 后来.通过查阅,发现了pssh这个工具,于是就抽时间实践了一下,以下是我的一些实践跟使用心得(安装方法我就不在此叙述了):

     1. PSSH 的使用

     先看看说明文档:  man pssh

       

OPTIONS
       -h host_file   # -h + 包括IP的文件名称
           --hosts host_file
       -H     [user@]host[:port]  # -H + <span style="font-family: Arial, Helvetica, sans-serif;">[用户@]主机IP[:端口]   [  ]内的是可选參数 ,若有多个主机,用" "引起来,主机之间用空格分开</span>
           --host [user@]host[:port]
       -H     "[user@]host[:port] [ [user@]host[:port ] ... ]"  
       <span style="white-space:pre">	</span>   --host "[user@]host[:port] [ [user@]host[:port ] ... ]"
       -l user   # -l + username(用于连接远程主机的username)
           --user user
       -p parallelism   # -p + 并发数
           --par parallelism

       -t timeout   # -t + 超时秒数
           --timeout timeout
       -o outdir   # -o + 输出文件夹  说明:会在该文件夹下创建  <span style="font-family: Arial, Helvetica, sans-serif;">[用户@]主机IP[:端口]</span><span style="font-family: Arial, Helvetica, sans-serif;">  格式的文件名称,用于保存输出结果</span>
           --outdir outdir
       -e errdir   # -e + 错误输出文件夹  
          --errdir errdir
       -x args  # -x + ssh连接时可提供的參数 ,例: -x "-o StrictHostKeyChecking=no" 表示跳过ssh链接时询问yes/no 
           --extra-args args  
       -X arg
           --extra-arg arg
              
       -O options   # -O + SSH配置文件里的选项  能够出现多个 -O 选项
           --options options
       -A
           --askpass
       -i    # -i 參数用于将输出结果直接显示在当前终端
           --inline
            --inline-stdout
       -v  # -v 參数用于显示ssh连接时的错误信息
          --verbose

       -I
           --send-input
              Read input and send to each ssh process.  Since ssh allows a command script to be sent on standard input, the -I option may be used in lieu of the command argument.

       -P      # -P 參数用于当主机连接上之后,输出运行结果 ,先输出运行结果,再显示连接的主机信息.
           --print

         

     pssh  -h i2.txt “ifconfig”     

        pssh,pscp,pslurp使用实践[通俗易懂]

    如之前没有从pssh所在主机连接到目标机器,则运行时一定要家參数  -x “-o StrictHostKeyChecking=no” ,没有加该參数的情况:

       pssh,pscp,pslurp使用实践[通俗易懂]

   因为尚未在该机器上通过ssh连接过 XXXX.104 和 XXX.70,所以运行命令失败,有时会使得所以主机上的命令都运行失败,加上  -x “-o StrictHostKeyChecking=no”  參数后:

       pssh,pscp,pslurp使用实践[通俗易懂]

   上面的命令仅仅显示是否运行成功,但未显示运行命令的输出结果, 须要加上 -i 參数:

        pssh,pscp,pslurp使用实践[通俗易懂]

     

   指定输出文件夹 -o 參数:

      pssh,pscp,pslurp使用实践[通俗易懂]

  2. pscp 用于将本地文件拷贝到远程主机

     pscp 跟pssh 的非常多參数都是一样的,故不再多说.

     -r 參数用于递归拷贝文件夹

     pscp -h ip文件 本地文件  远程文件夹

       pssh,pscp,pslurp使用实践[通俗易懂]

   3 . pslurp 用于将远程主机上的文件复制回本地

        pslurp 參数跟pscp參数一样

        -L  參数用于指定本地存放文件的文件夹

        plurp -L   -h ip文件  远程文件 本地名称

       尽管帮助文档里说 -L 參数是可选的,可是经过我的实验发现-L 应该是必须的否则会报错,实验结果例如以下:

       pssh,pscp,pslurp使用实践[通俗易懂]

     添加 -L  參数后,会在-L 指定的本地文件夹下创建  [用户@]主机IP[:port] 文件夹,相应的文件夹下用于存放从该主机复制过来的文件.

    4 . pnuke 用于批量远程结束进程

      pnuke 的參数与pssh一样,仅仅是最后的字符串为要结束的进程名称

     如:  pnuke -h i2.txt  httpd  表示结束 i2.txt文件里全部主机的 httpd进程

   以上仅个人实验和使用心得,用于备忘,也希望能帮到一些同学 !微笑

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/116179.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 10个最新手机美食APP界面设计欣赏

    10个最新手机美食APP界面设计欣赏移动软件时代,简单下载美食app,动动手指,滑动几下手机屏幕,即可足不出户,搜索,预定和购买各路美食。然而,对于作为手机appUI界面设计师的你来说,最大的问题并不在于如何使用这些美食软件来方便生活,而是在于如何才能为各类餐厅,酒店,咖啡馆,水果以及饮料店设计出美观,舒适且简单易用的手机美食App,对吧?但是,已然为正在做的美食AppUI设计方案冥思苦想数小时或数天,却任然毫无头绪?究竟如何

    2022年6月19日
    77
  • supervisor添加进程_monitor进程

    supervisor添加进程_monitor进程Supervisor简介Supervisor超级用户,监管员Supervisor。超级用户是一个负责管理和维护网络的用户。supervisor是用Python开发的一个client/server服务,是Linux/Unix系统下的一个进程管理工具。可以很方便的监听、启动、停止、重启一个或多个进程。用supervisor管理的进程,当一个进程意外被杀死,supervisor监听到进程死后,会自动将它重启,很方便的做到进程自动恢复的功能,不再需要自己写shell脚本来控制。1.安装PIPw

    2025年10月20日
    3
  • php 替换字符串中的所有url 为a标签「建议收藏」

    php 替换字符串中的所有url 为a标签「建议收藏」functionformatUrlsInText($str){preg_match_all(‘/((http|ftp|https):\/\/)?([\w_-]+(?:(?:\.[\w_-]+)+))([\w.,@?^=%&amp;:\/~+#-]*[\w@?^=%&amp;\/~+#-])?/’,$str,$arr);if(!$arr[0]){…

    2022年5月10日
    35
  • 计算ip地址的有效范围是_ip地址如何计算

    计算ip地址的有效范围是_ip地址如何计算例如:ip:192.168.9.3子网掩码:255.255.254.0网关:192.168.9.11:IP地址=网络地址+主机地址,二进制为:110000001010100000001001000000112:子网掩码的二进制表示为:11111111111111111111111000000000解析:前面1的就是网络地址部分,后面0就是主机地址,所以此处有9位主机地址。3:网络地址=子网掩码&IP地址,即:192.168.8.04:广播地址=3中

    2022年10月20日
    2
  • 大数据–商品推荐系统介绍(上)

    这次我们介绍商品推荐系统:推荐系统是什么推荐引擎的分类常见的推荐算法混合的推荐机制(重要)推荐系统架构协同过滤的实现推荐引擎解决的几个问题主动的用户,通过类目和搜索进行引导,对结果页进行干预被动的用户,通过用户的历史行为分析,推荐用户可能感兴趣的商品。对商家来讲,帮助商家卖出更多的东西推荐系统是什么目的为了解决信息过载和用户无明确需求的问题,找到用户感兴趣的物品…

    2022年4月3日
    38
  • 详解linux中rsync的妙用[通俗易懂]

    详解linux中rsync的妙用[通俗易懂]????1.rsync备份服务器软件介绍:Rsync是一款开源的、快速的、多功能的、可实现全量及增长的本地或远程数据同步备份的优秀工具。增量备份:只同步变化的数据细腻些,主要利用了quickcheck算法实现同步原理:1)建立好网络连接2)先进行数据信息对比3)只将变化的数据进行增量备份2.rsync软件作用说明:(1v4cp/scp/rm/ls)本地数据备份:cp[root@backup~]#cp-a/etc/hosts/tmp/hosts_cp[root@backu

    2022年10月13日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号