集群同步分发脚本

写脚本之前 先安装服务
yum install rsync -y

#!/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=1; host<4; host++)); do
        #echo $pdir/$fname [email protected]$host:$pdir
 #       echo --------------- 192.168.226.11$host ----------------
 #       rsync -rvl $pdir/$fname [email protected]$host:$pdir
#done
 
#5 循环
for host in {hadoop1,hadoop2,hadoop3}; do
        #echo $pdir/$fname $user@$host:$pdir
        echo --------------- $host ----------------
        rsync -rvl $pdir/$fname $user@$host:$pdir
done


赋权
chmod 777 脚本名

使用

脚本名 文件名

你可能感兴趣的:(linux,shell)