《懒人Shell脚本》之五——一键修改分布式系统配置文件-阿里云开发者社区

开发者社区> laoyang360> 正文

《懒人Shell脚本》之五——一键修改分布式系统配置文件

简介: 0. 背景 分布式部署程序的时候,近20台机器部署了同样的环境进行数据采集。 当更换程序时,能否修改好一套,其他机器只需要一步scp,一步执行脚本。 一键修改配置,正是本文的目的。
+关注继续查看

1. 实现要求

1、修改*.sh的可执行权限;

2、自动获取表名称的前两个字符,相应所有文件名称统一修改;

3、修改配置文件中的mysql表名、mysql地址;

4、从其他已有填好的配置中读取并修改java程序执行的start_num, end_id值。


2. 核心脚本如下

简化版本:


[root@localhost tt_process_detail]# cat change_conf_sim.sh

#需要手动修改

dst_mysql_ip="10.0.1.30"


processName=$(echo `pwd` | awk -F "/" '{print $4}')

city_code=`echo ${processName:0:2}`


find ./ -name "*.sh" | xargs chmod a+x


#自动修改名称

for((i=1;i<=4;i++))

do

 mv yt_ent_p${i} ${city_code}_ent_p${i}

done;


#自动生成

dst_table_name="${city_code}_company_info"


#循环实现

for((i=1;i<=4;i++))

do

#从旧表中获取start_num, end_id值

#读取指定行的数字部分

 p_begin=`sed -n 30p ../${city_code}_process/${city_code}_ent_p${i}/conf/configuration.xml | grep -o '[0-9]\+'`

 p_end=`sed -n 36p ../${city_code}_process/${city_code}_ent_p${i}/conf/configuration.xml | grep -o '[0-9]\+'`


#将获取的旧表值写入到新表中

 sed -i "30s/<value>.*<\/value>/<value>${p_begin}<\/value>/" ./${city_code}_ent_p${i}/conf/configuration.xml

 sed -i "36s/<value>.*<\/value>/<value>${p_end}<\/value>/" ./${city_code}_ent_p${i}/conf/configuration.xml


 #修改配置

 sed -i "s#te_company_info#${dst_table_name}#g" ./${city_code}_ent_p${i}/conf/configuration.xml

 sed -i "s#10.8.5.10#${dst_mysql_ip}#g" ./${city_code}_ent_p${i}/conf/configuration.xml

done;

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

3. 变量嵌套变量举例

[root@localhost hz_process_detail]# cat test.sh

#!/bin/bash


p1_begin=11;

p2_begin=22;


for ((i=1;i<=2;i++))

do

 begin=p${i}_begin

 eval p_begin_no=$(echo \$$begin)

 echo $p_begin_no

done;

1

2

3

4

5

6

7

8

9

10

11

12

4.获取ip地址的方法:

[root@localhost tt_process_detail]# cat tt_ent_p1/conf/configuration.xml | grep "jdbc" | awk -F "/" {'print $3'}

10.0.1.30

1

2

4. 小结

1)能自动实现的,坚决不要手动修改。

2)20套程序,单纯手动修改,耗时近1个小时,包含排查错误、验证时间。

脚本实现,scp复制20套,各机器执行下脚本,10分钟之内搞定。

3)其中,关于shell下修改xml,stackoverflow提到xmlstarlet工具,回头研究下。

本文使用的取指定行,写指定行的取巧的方式。

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
复制查到到的文件到另一个目录(shell脚本)
Test:find ../../res.bak/item/ -type f -name "*.jpg" |xargs -n1 -i echo {}."abc" 控制台上可看到如下信息:   find .
611 0
SQL脚本修改数据库名称
USE master; GO DECLARE @SQL VARCHAR(MAX); SET @SQL='' SELECT @SQL=@SQL+'; KILL '+RTRIM(SPID) FROM master.
728 0
非常简单的部署脚本(JavaWeb项目)和部署项目教程
这个部署方式,前提需要通过WinSCP工具将本地Maven项目打成zip包放到Linux对应的用户目录下,然后执行脚本便可以完成一键部署。 大家看到下面的脚本,可以发现一个显著的特点,部署脚本内容基本都是Linux命令拼接而来的。
1391 0
ZooKeeper分布式入门实战(一)-基本安装配置等
1.1 zookeeper 简介 中间件,提供协调服务 作用于分布式系统,发挥其优势,可以为大数据服务 支持 Java, 提供 Java 和 C语言的客户端 API 1.
1074 0
Linux Shell脚本读写XML文件
在Linux下如何用Shell脚本读写XML?现有一个config.xml    192.168.1.45   1209   /home/john 需要修改里面的"server-ip", "server-port" and "import-path",用Shell脚本的参数$1,$2,$3来写入。
1715 0
+关注
348
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载