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

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

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

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

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

[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、获取配置文件中的内容。

1.shell脚本修改多台服务器上的某一个文件中的值。_第2张图片

步骤是1,2,3.

5.删除一个文件中的内容,然后追加自己需要的内容,这里的先将文件中的内容删除,然后添加1234进去。

1.shell脚本修改多台服务器上的某一个文件中的值。_第3张图片

 

 6.在某行的前一行或后一行添加内容

具休操作如下:

#匹配行前加
sed -i '/allow 361way.com/iallow www.361way.com' the.conf.file #匹配行前后 sed -i '/allow 361way.com/aallow www.361way.com' the.conf.file

而在书写的时候为便与区分,往往会在i和a前面加一个反加一个反斜扛 。代码就变成了:

sed -i '/2222222222/a\3333333333' test.txt sed -i '/2222222222/i\3333333333' test.txt

 

这就就可以很方便的看出要在某一行前或某一行后加入什么内容 。不过经常我记不住a 、i 那个是前那个是后。我的记法是a = after ,i = in front 。这样就知道 i 是前,a 是后了

 

7.找到需要修改的上面一行,然后修改下一行中我们要替换的部分。

sed '/Hbase.rootdir/{n;s/bgs-5p173-wangwenting/ABC/g}' /opt/hbase/conf/hbase-site.xml 

1.shell脚本修改多台服务器上的某一个文件中的值。_第4张图片

8.将配置文件中的一个key-value字样的一行给换掉。

sed -i 's|broker.id=.*|broker.id=${kafkaid1}|' /opt/kafka/config/server.properties

1.shell脚本修改多台服务器上的某一个文件中的值。_第5张图片

该配置文件的value值变成了3456789,也支持这种样式的broker.id: 1    不是等于号,是冒号空格+数字这样的格式。

  


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

你可能感兴趣的:(1.shell脚本修改多台服务器上的某一个文件中的值。)