完全分布式部署Hadoop集群准备(二)编写集群分发脚本
作者:互联网
编写集群分发脚本xsync
作用:配置所有节点的同步信息
在/usr/local/bin这个目录下存放的脚本,可以在系统任何地方直接执行
/usr/local/bin目录下
touch xsync
chmod 777 xsync
#!/bin/bash
#获取输入参数的个数.没有参数直接退出
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<4;host++));do
#echo $pdir/$fname $user@testnote0$host:$pdir
echo ----------------testnote0$host------------------
rsync -rvl $pdir/$fname $user@testnote0$host:$pdir
done
bug:写完脚本发现传递给testnote03出现错误信息,无法使用
必要说明:必须保证集群所有全部安装rsync才能同步
编写分发脚本xcall
需求分析:在所有主机上同时执行相同的命令
xcall +命令
#!/bin/bash
pcount=$#
if((pcount==0));then
echo no args;
exit;
fi
echo -------------localhost----------
$@
for((host=101; host<=108; host++)); do
echo ----------hadoop$host---------
ssh hadoop$host $@
done
#!/bin/bash
pcount=$#
if((pcount==0));then
echo no args;
exit;
fi
echo ---localhost----
$@
for((host=1;host<=3;host++));do
echo ---------testnote0$host------
ssh testnote0$host $@
done
标签:bin,p1,pdir,Hadoop,echo,host,pcount,集群,分布式 来源: https://blog.51cto.com/u_13985831/2836963