shell脚本——xsync

xsync脚本基于rsync工具,rsync 远程同步工具,主要用于备份和镜像。具有速度快、避免复制相同内容和支持符号链接的优点,它只是拷贝文件不同的部分,因而减少了网络负担。 
rsync -rvl $pdir/$fname $user@hadoop$host:$pdir 
常用参数: 
-r, –recursive 对子目录以递归模式处理 
-R, –relative 使用相对路径信息 
-l, –links 保留软链结 
-v, –verbose 详细模式输出,传输过程可见 
… 

/usr/local/bin 目录下创建 xsync 文件,向里面添加:

#!/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=0; host<5; host++)); do
        #echo $pdir/$fname [email protected]$host:$pdir
 #       echo --------------- 192.168.3.15$host ----------------
 #       rsync -rvl $pdir/$fname [email protected]$host:$pdir
#done

#5 循环
for host in {192.168.3.152, 192.168.3.153, 192.168.3.154, 192.168.3.158, 192.168.3.159 }; do
        #echo $pdir/$fname [email protected]$host:$pdir
        echo --------------- 192.168.3.15$host ----------------
        rsync -rvl $pdir/$fname $user@$host:$pdir
done

最后chmod a+x xsync给文件添加执行权限即可。

使用xsync filename就能将filename分发到集群中的各个节点中。

--------------------- 
作者:Chris Wu 
来源:CSDN 
原文:https://blog.csdn.net/perfer258/article/details/81433622 
版权声明:本文为博主原创文章,转载请附上博文链接!

你可能感兴趣的:(远程同步工具,xsync,LINUX)