一、Ansible配置处理程序
1、处理程序
1️⃣:处理程序是响应由其他任务触发的通知的任务
2️⃣:仅当任务在受管主机上更改了某些内容时,任务才通知其处理程序
3️⃣:每个处理程序具有全局唯一的名称,在playbook中任务块的末尾触发
4️⃣:如果没有任务通过名称通知处理程序,处理程序就不会运行
5️⃣:如果一个或多个任务通知处理程序,处理程序就会在play中的所有其他任务完成后运行一次
6️⃣:因为处理程序就是任务,所以可以在处理程序中使用他们将用于任何其他任务的模块;通常而言,处理程序被用于重新引导主机和重启服务
2、实施处理程序
1️⃣:处理程序可视为非活动任务,只有在使用notify语句显式调用时才会被触发
- 演示实例:
//查看playbook [root@localhost project]# cat playbook.yaml --- - hosts: all tasks: - name: install httpd yum: name: httpd state: present notify: //notify关键字指定需要触发的处理程序 - start httpd //要运行处理程序的名称 handlers: //handlers关键字表示处理程序任务列表的开头(与tasks同级别) - name: start httpd //被触发的处理程序(任务)的名称;注意:必须与notify指定的处理程序的名称相同 service: name: httpd state: started //执行play [root@localhost project]# ansible-playbook playbook.yaml PLAY [all] **************************************************************************************************************************************************************** TASK [Gathering Facts] **************************************************************************************************************************************************** ok: [client.example.com] TASK [install httpd] ****************************************************************************************************************************************************** changed: [client.example.com] RUNNING HANDLER [start httpd] ********************************************************************************************************************************************* changed: [client.example.com] PLAY RECAP **************************************************************************************************************************************************************** client.example.com : ok=3 changed=2 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0
2️⃣:一个任务可以在其notify部分中调用多个处理程序。Ansible将notify语句视为数组,并且迭代处理程序名称
- 演示实例:
//查看playbook [root@localhost project]# cat playbook.yaml --- - hosts: all tasks: - name: install httpd yum: name: httpd state: present notify: - start httpd - install mariadb-server handlers: - name: start httpd service: name: httpd state: started - name: install mariadb-server yum: name: mariadb-server state: installed //执行play [root@localhost project]# ansible-playbook playbook.yaml PLAY [all] **************************************************************************************************************************************************************** TASK [Gathering Facts] **************************************************************************************************************************************************** ok: [client.example.com] TASK [install httpd] ****************************************************************************************************************************************************** changed: [client.example.com] RUNNING HANDLER [start httpd] ********************************************************************************************************************************************* changed: [client.example.com] RUNNING HANDLER [install mariadb-server] ********************************************************************************************************************************** changed: [client.example.com] PLAY RECAP **************************************************************************************************************************************************************** client.example.com : ok=4 changed=3 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0
二、处理程序的好处
1、处理程序重要事项
1️⃣:处理程序始终按照play的handlers部分指定的顺序运行,它们不按在任务中由notify语句列出的顺序运行,或按任务通知它们的顺序运行
2️⃣:处理程序通常在相关play中的所有其他任务完成后运行,playbook的tasks部分中某一任务调用的处理程序,将等到tasks下的所有任务都已处理后才会运行
3️⃣:处理程序名称存在于各play命名空间中,如果两个处理程序被错误地给予相同的名称,则仅会运行一个
4️⃣:即使有多个任务通知处理程序,该处理程序依然仅运行一次,如果没有任务通知处理程序,它就不会运行
5️⃣:如果包含notify语句的任务没有报告changed结果(例如,软件包已安装并且任务报告ok),则处理程序不会获得通知,处理程序将被跳过,直到有其他任务通知它。只有相关任务报告了changed状态,Ansible才会通知处理程序