ansible下使用blockinfile添加配置信息到xml

#发文福利#

一、前言

1、目标:批量修改服务器上的xml配置文件
2、原配置文件的最后一部分内容如下
复制代码
[root@s40 tmp]# tail kahn.conf
  <value>nginx</value>
  <description>my nginx config!</description>
</property>

<property>
  <name>address</name>
  <value>shanghai.china</value>
</property>

</configuration>
3、要求:在倒数第二行的位置插入新的配置信息
复制代码
            <property1>
              <name1>kahn.config</name>
              <value1>hahahaha.hello world!</value>
            </property1>

二、ansible-playbook的写法

复制代码
---

- hosts: all
  gather_facts: no
  ignore_unreachable: yes
  tasks:
    - name: debug 1
      debug:
        msg: "hello , newgroup"

    - name: 往xml里插入一段配置信息
      blockinfile:
          path: /opt/tmp/hdfs-site.xml
          insertbefore: "</configuration>"
          block: |
            <property1>
              <name1>kahn.config</name>
              <value1>hahahaha.hello world!</value>
            </property1>
          marker: "#{mark} my marker kahn..."
		  state: present
      notify:
        - handler1

  handlers:
    - name: handler1
      command: /bin/bash -c "/usr/bin/sed -ie 's/<\/configuration>/\n<\/configuration>/g' /opt/tmp/kahn.conf"

说明:

1、insertbefore: "</configuration>" 指定在 </configuration>一行的前面插入新配置信息

2、marker: "#{mark} my marker kahn..." 指定自定义标记,注意#是linux下的注释,{mark}是固定写法,必须写。到时候再你的配置信息上下放会有标记开始和结束的信息,如#BEGIN my marker kahn...和#END my marker kahn...。为啥要加{mark},有这个标记,才能以后使用state: absent去删除块。

3、state: present 增加块。反之是state: absent,如果要删除块state: absent的前提是在增加的时候必须有marker: "#{mark}"是必不可少的。

4、notify: - handler1 是本次的拓展,自定义动作标签,当我们修改了配置文件后,就会触发将最后一行的</configuration>替换掉为</configuration>上面增加一个空行。(注意这是个迂回的方法,没能在ansible中找到给指定行增加空白行的方法。如果我们反反复复的这样弄的话,会在最后一行</configuration>前产生多条空行)

执行结果如下:

复制代码
[root@s40 tmp]# tail kahn.conf
  <value>nginx</value>
  <description>my nginx config!</description>
</property>

<property>
  <name>address</name>
  <value>shanghai.china</value>
</property>

<property1>
  <name1>kahn.config</name>
  <value1>hahahaha.hello world!</value>
</property1>

</configuration>
相关推荐
jacGJ6 小时前
记录学习--文件读写
java·前端·学习
毕设源码-赖学姐7 小时前
【开题答辩全过程】以 基于WEB的实验室开放式管理系统的设计与实现为例,包含答辩的问题和答案
前端
幻云20107 小时前
Python深度学习:从筑基到登仙
前端·javascript·vue.js·人工智能·python
信创天地7 小时前
自动化运维利器赋能信创:Ansible与SaltStack在国产系统的部署与批量管理实战
运维·自动化·ansible
我即将远走丶或许也能高飞9 小时前
vuex 和 pinia 的学习使用
开发语言·前端·javascript
钟离墨笺9 小时前
Go语言--2go基础-->基本数据类型
开发语言·前端·后端·golang
爱吃泡芙的小白白9 小时前
Vue 3 核心原理与实战:从响应式到企业级应用
前端·javascript·vue.js
卓怡学长10 小时前
m115乐购游戏商城系统
java·前端·数据库·spring boot·spring·游戏
老陈聊架构10 小时前
『AI辅助Skill』掌握三大AI设计Skill:前端独立完成产品设计全流程
前端·人工智能·claude·skill
Ulyanov11 小时前
从桌面到云端:构建Web三维战场指挥系统
开发语言·前端·python·tkinter·pyvista·gui开发