1.shell脚本修改多台服务器上的某一个文件中的值。

1.背景情况:由于分布式部署zookeeper,需要到每台服务器上修改 /opt/zookeeper/data/myid文件中的值,如果切换服务器修改,导致会浪费很多时间,如果是100台服务器修改,那就。。。。。。,所以这里写一个脚本再主节点机器上执行,就可以修改其他机器上同一个位置下的某个文件的值。

2.前面介绍过salt一键部署工具,可以将解压的包一次性群发到其他的服务器上,但是上次也说了对于群发之后的解压包,可能需要修改某个文件中的值,所以下面我们看看脚本如何去实现的。

3.我们将所有的机器ip或者域名写在一个zookeeper.txt文本文件中,在shell脚本中引用这个文件获取其中的ip或者域名的值。

[root@bgs-5p173-wangwenting zookeeper]# more zookeeper.sh 
for ip in $(< /srv/salt/zookeeper/t.txt);do               //这里是获取文本文件中的ip值
	if [ ${ip} == "bgs-5p174-wangwenting" ]
	then 
	  ssh hadoop@${ip} "sed -i 's/1/2/g' /opt/zookeeper/data/myid"        //进行判断如果等于这个ip,则ssh到这个机器上修改myid的值,将1改为2

        elif [ ${ip} == "bgs-5p175-wangwenting" ]
        then 
          ssh hadoop@${ip} "sed -i 's/1/3/g' /opt/zookeeper/data/myid"
        fi
done
[root@bgs-5p173-wangwenting zookeeper]# more zookeeper.txt 
bgs-5p173-wangwenting
bgs-5p174-wangwenting
bgs-5p175-wangwenting
[root@bgs-5p173-wangwenting zookeeper]# 

  4.有了salt工具和shell的脚本,我们便可以真正意义上的一键部署,所以如果部署hadoop,jdk,python,等组件都可以做到秒级安装部署。当前啦前提的准备工作要做充分。

posted @ 2017-05-16 19:50  wyl9527  阅读(1494)  评论(0编辑  收藏  举报