shell脚本——xsync
时间:2019-11-29 13:12 来源:linux.it.net.cn 作者:IT
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 $user@192.168.3.15$host:$pdir
# echo --------------- 192.168.3.15$host ----------------
# rsync -rvl $pdir/$fname $user@192.168.3.15$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 $user@192.168.3.15$host:$pdir
echo --------------- 192.168.3.15$host ----------------
rsync -rvl $pdir/$fname $user@$host:$pdir
done
最后chmod a+x xsync给文件添加执行权限即可。
使用xsync filename就能将filename分发到集群中的各个节点中。
(责任编辑:IT)
xsync脚本基于rsync工具,rsync 远程同步工具,主要用于备份和镜像。具有速度快、避免复制相同内容和支持符号链接的优点,它只是拷贝文件不同的部分,因而减少了网络负担。 在/usr/local/bin 目录下创建 xsync 文件,向里面添加:
最后chmod a+x xsync给文件添加执行权限即可。 使用xsync filename就能将filename分发到集群中的各个节点中。 (责任编辑:IT) |