微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐