其他分享
首页 > 其他分享> > 完全分布式部署Hadoop集群准备(二)编写集群分发脚本

完全分布式部署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