notify
notify这个action可用于在每个play的最后被触发,这样可以避免多次有改变发生时每次都执行指定的操作,取而代之,仅在所有的变化发生完成后一次性地执行指定操作。
在notify中列出的操作称为handler,也即notify中调用handler中定义的操作。
---
- name: test.yml just for test
hosts: testserver
vars:
region: ap-southeast-1
tasks:
- name: template configuration file
template: src=template.j2 dest=/etc/foo.conf
notify:
- restart memcached
- restart apache
handlers:
- name: restart memcached
service: name=memcached state=restarted
- name: restart apache
service: name=apache state=restarted
handlers
Handlers 也是一些 task 的列表,通过名字来引用,它们和一般的 task 并没有什么区别。
Handlers 是由通知者进行 notify, 如果没有被 notify,handlers 不会执行。
不管有多少个通知者进行了 notify,等到 play 中的所有 task 执行完成之后,handlers 也只会被执行一次。
Handlers 最佳的应用场景是用来重启服务,或者触发系统重启操作.除此以外很少用到了。
---
- name: test.yml just for test
hosts: testserver
vars:
region: ap-southeast-1
tasks:
- name: check memory free
template: src=template1.j2 dest=/etc/foo.conf
notify: restart apache
- name: check memory free
template: src=template2.j2 dest=/etc/okk.conf
notify: restart apache
handlers:
- name: restart apache
service: name=apache state=restarted
#//@Apache只会重启一次
#//@handlers需要等到所有tasks完成后才执行
参考链接
http://ansible-tran.readthedocs.org/en/latest/docs/playbooks_intro.html
http://www.21ops.com/ops/automate-ops/26711.html
转载请注明:IPCPU-网络之路 » Ansible入门notify和handlers