1.shell脚本修改多台服务器上的某一个文件中的值。
1.背景情况:由于分布式部署zookeeper,需要到每台服务器上修改 /opt/zookeeper/data/myid文件中的值,如果切换服务器修改,导致会浪费很多时间,如果是100台服务器修改,那就。。。。。。,所以这里写一个脚本再主节点机器上执行,就可以修改其他机器上同一个位置下的某个文件的值。2.前面介绍过salt一键部署工具,可以将解压的包一次性群发到其他的服务器上,但是上次也说了对于
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、获取配置文件中的内容。
步骤是1,2,3.
5.删除一个文件中的内容,然后追加自己需要的内容,这里的先将文件中的内容删除,然后添加1234进去。
6.在某行的前一行或后一行添加内容
具休操作如下:
而在书写的时候为便与区分,往往会在i和a前面加一个反加一个反斜扛 。代码就变成了:
这就就可以很方便的看出要在某一行前或某一行后加入什么内容 。不过经常我记不住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
8.将配置文件中的一个key-value字样的一行给换掉。
sed -i 's|broker.id=.*|broker.id=${kafkaid1}|' /opt/kafka/config/server.properties
该配置文件的value值变成了3456789,也支持这种样式的broker.id: 1 不是等于号,是冒号空格+数字这样的格式。
9.有了salt工具和shell的脚本,我们便可以真正意义上的一键部署,所以如果部署hadoop,jdk,python,等组件都可以做到秒级安装部署。当前啦前提的准备工作要做充分。
更多推荐
所有评论(0)