date: 2020-03-04title: ansible中的幂等性 #标题
tags: ansible的幂等性 #标签
categories: ansible # 分类

ansible中的幂等性

ansible中绝大多数的模块都具有幂等特性,意味着执行依次或多次不会产生副作用。但是shell、command、script、raw这四个模块时不满足幂等性,所有操作会重复执行,但是有些操作不允许重复执行,比如MySQL的初始化命令mysql_install_db,逻辑上它只在第一次配置的过程中初始化依次,其他任何时候都不应该再执行。所有,每当使用这四个模块的时候,都要想一想,重复执行这个命令会不会产生负面影响。
当然,在上面的四个模块中,除了raw模块外,都提供了实现幂等特性的参数,就是creates和removes:

  • creates参数:当指定的文件或目录存在时,则不执行命令;
  • removes参数:当指定的文件或目录不存在时,则不执行命令;

示例如下:

  1. ---
  2. - name: use some module
  3. hosts: node
  4. gather_facts: false
  5. tasks:
  6. # 网卡配置文件不存在时则不执行
  7. - name: use command module
  8. command: ifup ens33
  9. args:
  10. removes: /etc/sysconfig/network-scripts/ifcfg-ens33
  11. # mysql配置文件已存在时则不执行,避免覆盖
  12. - name: use shell module
  13. shell: cp /tmp/my.cnf /etc/my.cnf
  14. args:
  15. creates: /etc/my.cnf

经过测试可以证明,使用removes或creates参数之后,就可以实现幂等性,保证命令不会重复执行。

这四个模块都不限于执行shell命令或shell脚本,可以通过executable参数指定其他解释器,如expec执行expect脚本、perl解释器执行perl脚本等等。如下:

  1. [root@ansible ansible]# cat test.yaml
  2. ---
  3. - name: RUN a perl script
  4. script: /some/local/script.pl
  5. args:
  6. executable: perl