Linux:服务器间同步文件的脚本(实用)

一、功能描述

比如有三台服务器,hadoop102、hadoop103、hadoop104,且都有atguigu账号

循环复制文件到所有节点的相同目录下,且脚本可以在任何路径下使用

二、脚本实现

1、查看环境变量

bash 复制代码
echo $PATH

2、进入/home/atguigu/bin目录

在该目录下创建脚本,则该脚本可以在任何路径下使用,因为,这个路径添加在环境变量中

3、创建脚本文件xsync

shell 复制代码
#!/bin/bash

#1. 判断参数个数
if [ $# -lt 1 ]
then
	echo Not Enough Arguement!
	exit;
fi

#2. 遍历集群所有机器
for host in hadoop102 hadoop103 hadoop104
do
	echo ==================== $host ====================
	#3. 遍历所有目录,挨个发送
	for file in $@
	do
		#4. 判断文件是否存在
		if [ -e $file ]
			then
				#5. 获取父目录
				pdir=$(cd -P $(dirname $file); pwd)
				#6. 获取当前文件的名称
				fname=$(basename $file)
				ssh $host "mkdir -p $pdir"
				rsync -av $pdir/$fname $host:$pdir
			else
				echo $file does not exists!
		fi
	done
done

4、修改脚本权限

bash 复制代码
chmod 777 xsync

三、优化

如果想在执行脚本的时候,避免输入服务器密码,那么,需要配置服务器间的免密登陆

参考:Linux服务器间配置免密登陆

相关推荐
ICscholar4 小时前
ExaDigiT/RAPS
linux·服务器·ubuntu·系统架构·运维开发
sim20204 小时前
systemctl isolate graphical.target命令不能随便敲
linux·mysql
米高梅狮子5 小时前
4. Linux 进程调度管理
linux·运维·服务器
再创世纪6 小时前
让USB打印机变网络打印机,秀才USB打印服务器
linux·运维·网络
fengyehongWorld7 小时前
Linux ssh端口转发
linux·ssh
知识分享小能手8 小时前
Ubuntu入门学习教程,从入门到精通, Ubuntu 22.04中的Shell编程详细知识点(含案例代码)(17)
linux·学习·ubuntu
Xの哲學9 小时前
深入解析 Linux systemd: 现代初始化系统的设计与实现
linux·服务器·网络·算法·边缘计算
龙月9 小时前
journalctl命令以及参数详解
linux·运维
EndingCoder10 小时前
TypeScript 的基本类型:数字、字符串和布尔
linux·ubuntu·typescript
YJlio10 小时前
Kali Linux 外置无线网卡接入与识别排障(VMware 环境|合规学习版)
linux·网络·学习