1.异步操作和轮询
默认情况下,剧本中的任务会一直处于打开状态,直到任务在每个节点上完成。
这样可以会造成阻塞和超时,因此我们可以使用异步模式一次运行所有任务,然后轮询直到它们完成为止。
Ansible本身就是采用的多线程来操作多个主机节点,可以使用-P来异步操作。
现在所说的异步操作和轮询是针对单个任务来说的。
(1)超时
如果你想避免因为连接超时问题导致任务执行失败,可以指定poll轮询次数,
这样就不会因为一次没连上就报错。
--- - hosts: all tasks: - name: "默认长时间运行操作,最多等待45秒,轮询5次" command: /bin/sleep 15 async: 45 poll: 5
async是异步时长,如果没有指定就是同步操作。
poll代表轮询次数,默认值15.
执行结果:
(2)并发
如果poll为0,Ansible启动任务之后会立即转到下一个任务,这样就会并发执行任务。
通过指定poll为0,可以来异步运行任务。
如果使用--forks来执行异步任务,效率会更高。
如果希望异步任务执行并稍后检查,可以这样
- name: 'YUM - async task' yum: name: docker-io state: present async: 1000 poll: 0 register: yum_sleeper - name: 'YUM - check on async task' async_status: jid: "{{ yum_sleeper.ansible_job_id }}" register: job_result until: job_result.finished retries: 30
2.滚动更新
你现在有100个节点,你想分批次操作,比如一次操作10台,就可以使用serial参数来定制。
现在我有两个节点:
常规方式来执行任务:
serial1.yaml
--- - hosts: all gather_facts: False tasks: - name: task one command: hostname - name: task two command: hostname
执行结果:
执行一次,执行了两个任务。
现在添加serial=1,在此查看结果:
我们发现,现在是分两次执行了。
我们不仅可以指定没批执行的数量,还可以指定比率。
serial: "30%"
还可以指定一个列表:
serial:
- 1
- 5
- 10
第一批1台,第二批执行5台,这样循环着来。
当然可以将多个批次使用百分比列出:
serial:
- "10%"
- "20%"
- "100%"
混合定义也是可以的:
serial:
- 1
- 5
- "20%"
这个功能有什么用了,现在有10个任务,常规做法是所有的机器执行完task1之后,再执行task2,
如果task2有问题,那么这批操作不就作废吗,如果第一批只执行一台,那么就立刻检测出task2任务的异常了。
这样可以大大提高效率。
3.最大故障率
默认情况下,只要批处理中存在尚未失败的主机,Ansible就将继续执行。
我们可以通过max_fail_percentage参数来指定故障了。
max_fail_percentage: 30
如果10台中有3台出现问题,操作即结束。
4.跑一次
在某些情况下,可能只需要对一批主机运行一次任务,可以通过run_one参数来实现。
run_once: true
该指令强制任务在当前批次的第一个主机上执行任务,然后将所有结果同步给同一批次的其它主机。
5.本地剧本
如果要在本机上执行剧本,只需要:
ansible-playbook playbook.yml --connection=local
或者在剧本中指定:
- hosts: 127.0.0.1
connection: local