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服务器间配置免密登陆

相关推荐
网络与设备以及操作系统学习使用者6 分钟前
vi与vim在openEuler中的差异及应用
linux·运维·网络·学习·vim
专注VB编程开发20年10 分钟前
python运行提速方案全解
java·linux·服务器
相思难忘成疾11 分钟前
Ubuntu 入门:安装、网络、软件一站式教程
linux·网络·ubuntu
luoqice1 小时前
linux下安装rtsp流媒体服务器
linux·音视频
学困昇1 小时前
Linux IPC 详解:匿名管道、命名管道、共享内存与信号量
linux·运维·服务器·c语言·c++·人工智能
汽车搬砖家2 小时前
VM Fusion安装Ubuntu系统
linux
AI小小怪2 小时前
保姆级教程:Ubuntu 22.04 安装 NVIDIA GPU 驱动 + CUDA 12.6(RTX 3080 显卡)
linux·nvidia·cuda
Embedded-Xin2 小时前
ROS2进阶——消息服务质量QOS策略
linux·机器人·嵌入式
Embedded-Xin2 小时前
ROS2进阶—ROS2生命周期节点
linux·机器人·自动驾驶·嵌入式
比昨天多敲两行2 小时前
Linux.基础I/O
linux