ansible中的幂等性

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ansible中的幂等性相关的知识,希望对你有一定的参考价值。

1、ansible中的幂等性

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

当然,在上面的四个模块中,除了raw模块外,都提供了实现幂等特性的参数,就是creates和removes:

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

示例如下:

---
- name: use some module
  hosts: node
  gather_facts: false
  tasks:
  # 网卡配置文件不存在时则不执行
  - name: use command module
    command: ifup ens33
    args:
      removes: /etc/sysconfig/network-scripts/ifcfg-ens33

  # mysql配置文件已存在时则不执行,避免覆盖
  - name: use shell module
    shell: cp /tmp/my.cnf /etc/my.cnf
    args:
      creates: /etc/my.cnf

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

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

[root@ansible ansible]# cat test.yaml 
---
- name: RUN a perl script
  script: /some/local/script.pl
  args:
    executable: perl

以上是关于ansible中的幂等性的主要内容,如果未能解决你的问题,请参考以下文章

分布式系统中的幂等性问题

分布式架构中的幂等性

HTTP中的幂等性

幂等和高并发在电商系统中的使用

接口服务中的幂等性设计和防重保证,详细分析幂等性设计几种实现方法

分布式服务的幂等性设计