Linux 下自动化工具 Parallel SSH 中文使用指南
ahcoder 2025-01-10 11:20 29 浏览
parallel-ssh 是为小规模自动化而设计的异步并行的 SSH 库!
parallel-ssh 是为小规模自动化而设计的异步并行的 SSH 库,包括 pssh、pscp、prsync、pslurp 和 pnuke工具,其源代码使用 Python语言编写开发的。该项目最初位于Google Code上,是由Brent N.Chun编写和维护的,但是由于工作繁忙,Brent于2009年10月将维护工作移交给了Andrew McNabb管理。到了 2012年的时候,由于Google Code的已关闭,该项目一度被废弃,现在也只能在 Google Code 的归档中找到当时的版本了。
但是需要注意的是,之前的版本是不支持 Python3 的,但是 Github 上面有人 Fork 了一份,自己进行了改造使其支持 Python3 以上的版本了。与此同时,还有一个组织专门针对 parallel-ssh 进行了开发和维护,今天看了下很久都没有更新了。有需要的,自己可以自行查阅。
- https://github.com/lilydjwg/pssh
- https://github.com/ParallelSSH/parallel-ssh
- 可扩展性
- 支持扩展到百台,甚至上千台主机使用
- 易于使用
- 只需两行代码,即可在任意数量的主机上运行命令
- 执行高效
- 号称是最快的 Python SSH 库可用
- 资源使用
- 相比于其他 Python SSH 库,其消耗资源最少
安装
# Mac系统安装
nbsp;brew install pssh
# CentOS系统安装
nbsp;yum install pssh
# Ubuntu系统安装
nbsp;apt install pssh
# PIP安装
nbsp;pip insall pssh
源代码编译安装(2.3.1)
# 官方地址: https://code.google.com/archive/p/parallel-ssh/source/default/source
nbsp;tar zxvf pssh-2.3.1.tar.gz
nbsp;cd pssh-2.3.1
nbsp;python setup.py install
# 工具对应的子命令子命令
nbsp;ls -lh /usr/local/Cellar/pssh/2.3.1_1/bin/
pnuke -> ../libexec/bin/pnuke
prsync -> ../libexec/bin/prsync
pscp -> ../libexec/bin/pscp
pslurp -> ../libexec/bin/pslurp
pssh -> ../libexec/bin/pssh
pssh-askpass -> ../libexec/bin/pssh-askpass
pssh
通过 ssh 协议在多台主机上并行地运行命令
命令参数使用
适用范例
# Usage: pssh [OPTIONS] command [...]
# 在两个主机上运行命令并在每个服务器上打印其输出
nbsp;pssh -i -H "host1 host2" hostname -i
# 运行命令并将输出保存到单独的文件中
nbsp;pssh -H host1 -H host2 -o path/to/output_dir hostname -i
# 在多个主机上运行命令并在新行分隔的文件中指定
nbsp;pssh -i -h path/to/hosts_file hostname -i
# 以root运行命令(要求输入root用户密码)
nbsp;pssh -i -h path/to/hosts_file -A -l root_username hostname -i
# 运行带有额外SSH参数的命令
nbsp;pssh -i -h path/to/hosts_file -x "-O VisualHostKey=yes" hostname -i
# 运行并行连接数量限制为10的命令
nbsp;pssh -i -h path/to/hosts_file -p 10 'cd dir; ./script.sh; exit'
2. pscp
通过 ssh 协议把文件并行地复制到多台主机上
命令参数使用
适用范例
# Usage: pscp [OPTIONS] local remote
# 将本地文件复制到远程机器上
nbsp;pscp -h hosts.txt -l root foo.txt /home/irb2/foo.txt
[1] 23:00:08 [SUCCESS] 172.18.10.25
[2] 09:52:28 [SUCCESS] 172.18.10.24
3. prsync
通过 rsync 协议把文件高效地并行复制到多台主机上
命令参数使用
适用范例
# Usage: prsync [OPTIONS] local remote
# 使用rsync协议进行本地文件复制操作
nbsp;prsync -r -h hosts.txt -l root foo /home/irb2/foo
4. pslurp
通过 ssh 协议把文件并行地从多个远程主机复制到中心主机上
命令参数使用
适用范例
# Usage: pslurp [OPTIONS] remote local
# 将远程主机上面的文件复制到本地
nbsp;pslurp -h hosts.txt -l root -L /tmp/outdir /home/irb2/foo.txt foo.txt
5. pnuke
通过 ssh 协议并行地在多个远程主机上杀死进程
命令参数使用
适用范例
# Usage: pnuke [OPTIONS] pattern
# 结束远程主机上面的进程任务
nbsp;pnuke -h hosts.txt -l root java
相关推荐
- Java程序员必备的Linux命令速查表
-
Java程序员必备的Linux命令速查表在Java开发的世界里,Linux就像一位默默支持的幕后英雄。作为一名Java开发者,掌握一些基本的Linux命令,不仅能提高工作效率,还能让你在团队中显得格外...
- Linux 命令速查手册:这 30 个高频指令,拯救 90% 的运维小白!
-
在Linux系统的世界里,命令行是强大的武器。对于运维小白而言,掌握一些高频使用的Linux命令,能极大提升工作效率,轻松应对各种系统管理任务。今天,就为大家奉上精心整理的30个Linu...
- linux磁盘管理相关命令(linux磁盘管理常用命令)
-
磁盘的使用情况会直接影响系统的性能,因此我们经常会用到以下命令,主要围绕:fdisk:磁盘分区df:文件系统的磁盘空间占用情况du:文件目录的磁盘空间占用情况查看磁盘关系lsblk查看磁盘分区情况fd...
- 第四章 Linux常用shell命令-4.5.磁盘管理
-
主要介绍一下跟磁盘管理相关命令,有比较多的内容摘抄自网络,如有侵权,请及时联系我删除:显示目前在Linux系统上的文件系统磁盘使用情况统计:df创建和维护分区表的程序:fdisk将磁盘分区或镜像挂...
- Linux新手必备:20个高效命令轻松掌握!
-
Linux基本命令使用指南在现代计算机操作系统中,Linux因其开放性、灵活性和强大的功能,广泛应用于服务器和开发环境中。作为技术人员,掌握Linux的基本命令是非常重要的。在本文中,我们将重点介绍2...
- 每日必学Linux命令:ls命令(linux命令详解之ls命令)
-
ls命令是linux下最常用的命令。ls命令就是list的缩写缺省下ls用来打印出当前目录的清单如果ls指定其他目录那么就会显示指定目录里的文件及文件夹清单。通过ls命令不仅可以查看linux文件...
- Linux系统dev和proc目录详解(linux dev/sr0)
-
简介:Linux系统里的/dev和/proc目录那可是相当重要的系统文件。在Linux系统中,/dev目录专门用来存放设备文件。不光有设备文件,系统里还有好多特殊功能也是通过设备的形式...
- Linux切换目录之cd命令(linux切换指定目录)
-
1.基本概念1.1命令作用当我们在Linux系统上工作时,做得相当多的一项任务就是在不同的目录之间进行切换,这时就需要用到cd命令了。cd是"changedirectory"的首...
- Linux切换目录(cd命令)(linux如何切换到目录)
-
cd命令,是ChangeDirectory的缩写,用来切换工作目录。Linux命令按照来源方式,可分为两种,分别是Shell内置命令和外部命令。所谓Shell内置命令,就是Shel...
- MongoDB数据库的快速部署和启动(mongodb的使用教程)
-
一、Mongodb介绍常见数据库介绍关系数据库RDBMS设计表结构,通过SQL语句进行操作。连表关系常见的关系型数据库:mysqloracle(商业)DB2(IBM)sqlserver(微软...
- 5分钟学会网络服务搭建,飞凌i.MX9352 + Linux 6.1实战示例
-
在“万物互联”的技术浪潮下,网络服务已成为连接物理世界与数字世界的核心纽带,它不仅赋予了终端设备“开口说话”的能力,更构建了智能设备的开发范式。本文就将以飞凌嵌入式OK-MX9352-C开发板(搭载了...
- centos安装geoserver并配置开机启动
-
前提条件:服务器已经安装了java环境一、下载下载地址:http://geoserver.org/release/maintain/下载后文件名为:geoserver-2.19.3-bin.zip二、...
- 开机启动流程(开机流程图)
-
grubandbootCentos5,6的开机启动流程grubCentos7的开机启动流程Centos5,6的开机启动流程initrd/initramfs一般存储在/boot目录下,以.img...
- Linux cron服务概述(crontab服务)
-
cron是Linux/Unix系统中一个非常重要的后台服务(守护进程),用于在预定的时间间隔自动执行命令或脚本。它使得自动化重复性任务成为可能,例如日志清理、数据备份、系统维护等。1.cron...
- CentOS 8利用rc.local进行开机自启动的配置
-
CentOS8利用rc.local进行开机自启动的配置CentOS8linux系统是不建议使用rc.local进行开机自启动的,建议创建systemdservice。我们为了方便以后多一个配置...
- 一周热门
- 最近发表
- 标签列表
-
- linux 远程 (37)
- u盘 linux (32)
- linux 登录 (34)
- linux 路径 (33)
- linux 文件命令 (35)
- linux 是什么 (35)
- linux 界面 (34)
- 查看文件 linux (35)
- linux 语言 (33)
- linux代码 (32)
- linux 查看命令 (33)
- 关闭linux (34)
- root linux (33)
- 删除文件 linux (35)
- linux 主机 (34)
- linux与 (33)
- linux 函数 (35)
- linux .ssh (35)
- cpu linux (35)
- 查看linux 系统 (32)
- linux 防火墙 (33)
- linux 手机 (32)
- linux 镜像 (34)
- linux ip地址 (34)
- linux 用户查看 (33)