rsync 远程同步工具
rsync主要用于备份和镜像。具有速度快、避免复制相同内容和支持符号链接的优点。
选项 | 功能 |
---|---|
-r | 递归 |
-v | 显示复制过程 |
-l | 拷贝符号连接 |
scp(secure copy)安全拷贝
scp可以实现服务器与服务器之间的数据拷贝。(把所有文件都复制过去)
*rsync和scp区别:用rsync做文件的复制要比scp的速度快,rsync只对差异文件做更新。
xsync集群分发脚本
循环复制文件到集群所有节点相同的目录下
1.新建xsync脚本文件
(在/user/local/bin这个目录下存放的脚本,用户可以在系统任何地方直接执行。)
touch xsync
2.进入文件编辑
vi 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=2; host<5; host++)); do
# echo $pdir/$fname $user@hadoop00$host:$pdir
echo --------------- hadoop00$host ----------------
rsync -rvl $pdir/$fname $user@hadoop00$host:$pdir
done
#5 循环
#for host in {hadoop001,hadoop002,hadoop003,hadoop004,hadoop005}; do
# echo $pdir/$fname $user@$host:$pdir
# echo --------------- $host ----------------
# rsync -rvl $pdir/$fname $user@$host:$pdir
#done
修改脚本具有执行权限
chmod 777 xsync
调用脚本形式: xsync 文件名
xsync /home/001/bin