【Parallel SSH】Ubuntu系统配置pssh实现多主机并行执行Master分发的命令

文章目录

  • 一、配置多机免密登录
  • 二、ubuntu系统安装pssh
  • 三、并行命令脚本编写

一、配置多机免密登录

假设有1台主机作为Master分发命令,3台主机作为Servers执行命令。假设Master主机内网IP地址为192.168.0.12,Servers外网IP及对应的hostname分别为:

191.229.196.150 Client1
115.220.157.181 Client2
198.54.177.207 Client3

为了避免切换身份带来的权限问题,这里配置Master以root身份通过SSH免密登录Servers(同样是root),如何配置root作为默认登录使用的教程参考此篇文章。
首先,配置Master的/etc/hosts,在末尾添加以下內容,这里假设Master的hostname也叫Master(必要时可删除第一二行本地回环地址)

192.168.0.12 Master
191.229.196.150 Client1
115.220.157.181 Client2
198.54.177.207 Client3

在Master上生成密钥传输给所有的Servers:

ssh-keygen
cat id_rsa.pub >> authorized_keys
ssh-copy-id -i id_rsa.pub -p22 root@Client1

测试是否可以免密登录,成功后exit即可退出:

ssh Client1

二、ubuntu系统安装pssh

不知道是哪个起效果,反正可以都安装一遍:

sudo apt-get update
sudo apt-get install parallel
sudo apt-get install pssh

测试paraller-ssh是否安装成功

parallel-ssh --version

三、并行命令脚本编写

如果要实现多个Servers对各自某个路径下的文件进行操作(如查询使用量),或者多个Servers执行同一个命令(如清理缓存),可参考以下脚本编写(注意循环内的&一定不能丢,要不然就是顺序执行,不是并行了):

#!/bin/bashservers=("Client1" "Client2" "Client3")
folders=("/path/to/client1_folder" "/path/to/client2_folder" "/path/to/client3_folder")
My_ssh() {server="$1"folder="$2"ssh -o StrictHostKeyChecking=no -o ConnectTimeout=10 -p 22 "$server" " time du -sh '$folder'"ssh -o StrictHostKeyChecking=no -o ConnectTimeout=10 -p 22 "$server" " sync;echo 3 > /proc/sys/vm/drop_caches "
}export -f My_sshfor i in "${!servers[@]}"; do(output_file="output_${i}.txt"parallel -j 5 My_ssh ::: "${servers[i]}" ::: "${folders[i]}" > "$output_file") &
donewaitecho "All operations have been completed."

保存为XXX.sh,赋予其可执行命令,在Master主机上执行,执行结果保存为多个output_n.txt:

chmod +x XXX.sh
./XXX.sh

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/45411.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

最新盘点!2024年最值得了解的24款项目管理软件

一、企业该如何选择一款项目管理工具?选择项目管理工具时需要考虑哪些因素? 在选择和对比项目管理工具时,可以通过加权方式进行对比和评估。参考以下模板,可以把自己关注的项目管理工具,进行表格对比,选中…

企业智能制造赋能的环境条件为什么重要?需要准备什么样的环境?

在全球制造业不断演进的今天,智能制造已经成为推动行业创新和转型的关键力量。它不仅代表了技术的革新,更是企业管理模式和运营思路的全面升级。然而,智能制造的落地实施并非一蹴而就,它需要企业在环境条件上做好充分的准备&#…

jail内部ubuntu apt升级失败问题解决-Dynamic MMap ran out of room

在FreeBSD jail 里安装启动Ubuntu jammy系统,每次装好执行jexec ubjammy sh进入Ubuntu系统后,执行apt update报错。 这个问题困惑了好久,突然有一天仔细去看报错信息,查看了(man 5 apt.conf) ,才搞定问题。简单来说就是…

Mybatis拦截器介绍及其应用

Mybatis拦截器介绍及其应用 1、介绍 Mybatis拦截器设计的初衷就是为了供用户在某些时候可以实现自己的逻辑而不必去动Mybatis固有的逻辑。通过Mybatis拦截器我们可以拦截某些方法的调用,我们可以选择在这些被拦截的方法执行前后加上某些逻辑,也可以在执…

Pycharm与Gitlab交互

环境准备 1、下载配置好本地Git 2、配置Pycharm上的Git 3、gitlab账号 Gitlab配置 Gitlab配置中文 账号》设置》偏好设置》简体中文 创建项目 命令行操作 打开项目会展示以下步骤 在pycharm克隆gitlab的项目 通过菜单栏 1、在PyCharm的顶部菜单栏中,选择“V…

本地部署,Flash Diffusion: 加速条件扩散模型实现快速图像生成

目录 引言 技术背景 Flash Diffusion 的架构与原理 Flash Diffusion 的主要特点 本地部署 运行结果 实验结果与分析 应用实例 结论 GitHub - gojasper/flash-diffusion: Official implementation of ⚡ Flash Diffusion ⚡: Accelerating Any Conditional Diffusion M…

Linux系统搭建轻量级个人博客VanBlog并一键发布公网远程访问

文章目录 前言1. Linux本地部署2. VanBlog简单使用3. 安装内网穿透4. 创建公网地址5. 创建固定公网地址 前言 今天和大家分享如何在Linux Ubuntu系统搭建一款轻量级个人博客VanBlog,并结合cpolar内网穿透软件生成公网地址,轻松实现随时随地远程访问本地…

相交链表+判断环型链表+求环型链表的入口节点

链表OJ题 一.相交链表二.判断环型链表三.求环型链表的入口节点 一.相交链表 相交链表 相交:两个链表从头开始遍历,尾节点一定是同一个节点。 情况一:当两个链表长度相同时: 情况二:当两个链表长度不同时&#xff1…

考研党暑假回家还是留校,暑假回家就一定完蛋吗?

考研我建议最好还是留校,因为环境比较好! 并不是说回家复习就一定不好,回家要面临三大“敌人”: 1、我们本身的惰性,这个无需多言,在自己熟悉的环境,自己一个人,手机电脑网络零食俱…

python条件

条件语句 if语句 if...else语句 if...elif...else语句 嵌套 is is 是一个身份运算符,用于比较两个对象的身份,即它们在内存中的地址是否相同。这与比较两个对象是否相等的 运算符不同。 运算符比较的是两个对象的值是否相等。 比较对象 比较基本数据…

【Unity】RPG2D龙城纷争(十一)战斗系统之回合制驱动

更新日期:2024年7月11日。 项目源码:第五章发布(正式开始游戏逻辑的章节) 索引 简介一、开始关卡二、进入指定回合三、玩家结束当前回合四、进入下一回合五、通关条件六、检测关卡状态简介 通过前两篇的工作,我们的角色已经能够进行移动、战斗了,此刻,便进入第三个板块…

React基础学习-Day04

React基础学习-Day04 常见的钩子函数及基础使用方式 1.useState useState 是 React 的一个 Hook,用于在函数组件中添加状态。它返回一个状态变量和一个更新该状态的函数。与类组件的 this.state 和 this.setState 相对应,useState 让函数组件也能拥有…

存储实验:Linux挂载iscsi硬盘与华为OceanStor创建LUN全流程

目录 目的环境规划实验实验流程Centos配置0. 关闭防火墙1. 设置网卡信息2. 配置路由3. iscsiadm连接存储 iSCSI LUN创建(以华为OceanStor为例)验证1. 验证是否成功2. 开启自动挂载 目的 实现Linux连接iscsi硬盘,同时实现开机自启挂载 环境规…

掌握本地仓储:Gradle本地仓库配置全指南

掌握本地仓储:Gradle本地仓库配置全指南 在构建自动化的领域中,Gradle以其灵活性和强大的依赖管理功能脱颖而出。管理项目依赖时,经常需要配置本地仓库以优化构建速度、控制依赖版本或支持离线构建。本文将深入探讨如何在Gradle中配置本地仓…

JAVA----泛型

泛型 认识泛型 定义类、接口、方法时,同时声明了一个或者多个类型变量(如:) ,称为泛型类、泛型接口,泛型方法、它们统称为泛型。 作用:利用泛型,可以限制集合存储数据的类型. 泛型…

Gitee简易使用流程(后期优化)

目录 1.修改用户名 2.文件管理 新建文件/文件夹流程如下: 上传文件流程如下: 以主页界面为起点 1.修改用户名 点解右上角的头像--> 点击“账号设置” 点击左边栏里的“个人资料“ 直接修改用户名即可 2.文件管理 选择一个有修改权限仓库&#…

【从0到1进阶Redis】主从复制

笔记内容来自B站博主《遇见狂神说》:Redis视频链接 1、概念 主从复制,是指将一个台 Redis 服务器的数据,复制到其他的 Redis 服务器。前者称为主节点(master/leader),后者称为从节点(slave/foll…

this指向解析

先看题目: 第一题: var name window var person1 { name: person1, show1: function () { console.log(this.name) }, show2: () > console.log(th show3: function () { return function () { …

MFC之对话框--重绘元文件

文章目录 实现示例展示需要绘制的窗口/位置控件位置更新下一次示例粗细滑动部分更新 重绘元文件(窗口变化内容消失)方法一:使用元文件方法二:兼容设备方法三:使用自定义类存储绘图数据除画笔外功能处理画笔功能处理 保…

springmvc1

以前的servlet程序: springmvc 不同的处理器:不同的方法或者处理类 所有的请求都会经过dispathcherservlet的doservice方法: mvc原理: 前端控制器:jsp或者什么东西