集群管理脚本


虚拟机集群管理脚本

文章目录

一、远程调用脚本(remote_call.sh)

如果有传命令参数,则执行该命令;如果没有传命令参数,则不执行。

shell 复制代码
#!/bin/bash

cmd=$1
if [ ! $cmd ];then
        cmd="jps"
fi

# 提取集群免密通信的虚拟机主机名
hosts=`sed -n '3,$p' /etc/hosts | awk '{print $2}'`

# 遍历所有主机
for host in $hosts;do
        echo "-------- $host --------"
        # 此处使用"$cmd"的原因是避免将命令中的空格识别为多条命令
        ssh root@$host "$cmd"
done
二、远程复制目录脚本(remote_copy.sh)

首先,要验证待复制的目录在本机是否存在;然后需要从/etc/hosts文件中获取除去当前主机名的其他主机名,并且对每个主机进行循环操作,先判断父目录是否存在,再进行递归复制。

shell 复制代码
#!/bin/bash

path=$1 # 本机目录

# 验证路径是否存在
if [ ! -e $path ];then
        echo "目录 $path 不存在,无法拷贝"
        exit 0
fi

# 提取集群中排除当前主机名之外的所有主机名
# 只需验证父目录是否存在即可
me=`hostname`
parent=`dirname $path`
hosts=`sed -n '3,$p' /etc/hosts | awk '{print $2}' | grep -v "$me"`

for host in $hosts;do
        scp -r $path root@$host:$parent
        echo "-------- 拷贝 $path 到 $host 成功 --------"
done
相关推荐
物理与数学5 小时前
Linux 内核 TLB 优化
linux·linux内核
啟明起鸣5 小时前
【Linux 项目管理工具】GDB 调试是现成 C/C++ 项目的 “造影剂”,用来分析项目的架构原理
linux·c语言·c++
物理与数学5 小时前
linux 交换分区(Swap)
linux·linux内核
南工孙冬梅6 小时前
【久久派】Linux 文件系统制作配置 基于buildroot
linux
宴之敖者、6 小时前
Linux——指令(下)
linux
抠脚学代码6 小时前
Qt与Linux
linux·数据库·qt
Code Warrior6 小时前
【Linux】多路转接poll、epoll
linux·服务器
跃渊Yuey6 小时前
【Linux】Linux进程信号产生和保存
linux·c语言·c++·vscode
CaspianSea6 小时前
清理 Ubuntu里不需要的文件
linux·运维·ubuntu
c++逐梦人6 小时前
命令⾏参数和环境变量
linux·操作系统·进程