shell脚本——xsync

2022-09-02 11:58:42 浏览数 (1)

大家好,又见面了,我是你们的朋友全栈君。

xsync脚本基于rsync工具,rsync 远程同步工具,主要用于备份和镜像。具有速度快、避免复制相同内容和支持符号链接的优点,它只是拷贝文件不同的部分,因而减少了网络负担。 rsync -rvl pdir/fname user@hadoophost:

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

代码语言:javascript复制
#!/bin/sh
# 获取输入参数个数,如果没有参数,直接退出
pcount=$#
if((pcount==0)); then
        echo no args...;
        exit;
fi

# 获取文件名称
p1=$1
fname=`basename $p1`
echo fname=$fname
# 获取上级目录到绝对路径
pdir=`cd -P $(dirname $p1); pwd`
echo pdir=$pdir
# 获取当前用户名称
user=`whoami`
# 循环
for((host=1; host<=2; host  )); do
        echo $pdir/$fname $user@slave$host:$pdir
        echo ==================slave$host==================
        rsync -rvl $pdir/$fname $user@slave$host:$pdir
done
#Note:这里的slave对应自己主机名,需要做相应修改。另外,for循环中的host的边界值由自己的主机编号决定。

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

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

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/138521.html原文链接:https://javaforall.cn

0 人点赞