提前配置ssh无密登录:https://blog.csdn.net/qq_35241080/article/details/105850466
1、进入用户家目录,建立bin目录
[root@hadoop102 bin]# cd ~
[root@hadoop102 ~]# mkdir bin
[root@hadoop102 ~]# cd bin/
2、创建文件发送脚本
[root@hadoop102 bin]# touch xsync
[root@hadoop102 bin]# vimxsync
如下脚本内容:hadoop102、hadoop103、hadoop104 三台机器,将102的文件同步拷贝至103、104的相同位置
#!/bin/bash
#1 获取输入参数个数,如果没有参数,直接退出
pcount=$#
if((pcount==0)); then
echo no args;
exit;
fi
#2 获取文件名称
p1=$1
fname=`basename $p1`
echo fname=$fname
#3 获取上级目录到绝对路径
pdir=`cd -P $(dirname $p1); pwd`
echo pdir=$pdir
#4 获取当前用户名称
user=`whoami`
#5 循环同步
for((host=103; host<105; host++));
do
echo --------------------- hadoop$host ----------------
rsync -rvl $pdir/$fname $user@hadoop$host:$pdir
done
3、脚本赋权
[root@hadoop102 bin]# chmod 777xsync
4、测试脚本,在102 /root/bin 目录下新建1.txt文件使用脚本同步至103、104机器
最好在102需要先配置ssh无密登录103、104
[root@hadoop102 bin]# touch 1.txt
[root@hadoop102 bin]# xsync 1.txt
fname=1.txt
pdir=/root/bin
--------------------- hadoop103 ----------------
sending incremental file list
1.txt
sent 67 bytes received 31 bytes 196.00 bytes/sec
total size is 0 speedup is 0.00
--------------------- hadoop104 ----------------
sending incremental file list
1.txt
103、104需要在建立相同位置bin目录
[root@hadoop103 bin]# pwd
/root/bin
[root@hadoop103 bin]# ll
total 0
-rw-r--r--. 1 root root 0 2020-05-08 10:36:51 1.txt