Обработчики не запускаются после выполнения задачи

Я пытаюсь автоматизировать некоторые задачи с помощью Ansible. В моих playbooks у меня есть задача копирования, а затем я меняю права доступа к файлу. Мне нужно перезапустить сервис после этой задачи. Я включаю уведомление и также объявил мой обработчик, но странным образом этот обработчик никогда не вызывается.

Выдержка из моей пьесы

- name: Configure Audit Log Purge Scheduler
  copy:
    src: "Scheduler-Log-Purge.config"
    dest: "{{ crx_dir }}install/com.adobe.cq.audit.purge.Scheduler-LogPurge.config"
  become: true
  tags: aem

- name: Change Permissions of the Log Purge Scheduler config File
  file:
    path: "{{ crx_dir }}install/com.adobe.cq.audit.purge.Scheduler-LogPurge.config"
    owner: crx
    group: crx
  become: true
  notify: restart aem
  tags: aem

- name: Pause the execution for cq5 to come up
  pause:
    minutes: 5
  tags: aem

А вот и мой файл обработчика содержимого.

---

- name: restart aem
  service: name=cq5 state=restarted
  become: yes

О / п после запуска playbook

gparasha-macOS:TLTD gparasha$ ansible-playbook -i hosts tltd.yml --tags aem -v
No config file found; using defaults

PLAY [Run tasks on Author] **************************************************************************************************************************************************************

TASK [Gathering Facts] ******************************************************************************************************************************************************************
ok: [35.169.196.183]

PLAY [Run AEM Specific Steps on Author] *************************************************************************************************************************************************

TASK [Gathering Facts] ******************************************************************************************************************************************************************
ok: [35.169.196.183]

TASK [publish : Configure Audit Log Purge Scheduler] ************************************************************************************************************************************
ok: [35.169.196.183] => {"changed": false, "checksum": "3a9d00ea8357fd217a9442b1c408065abf077dfc", "failed": false, "gid": 1005, "group": "crx", "mode": "0644", "owner": "crx", "path": "/mnt/crx/author/crx-quickstart/install/com.adobe.cq.audit.purge.Scheduler-LogPurge.config", "secontext": "user_u:object_r:usr_t:s0", "size": 277, "state": "file", "uid": 1005}

TASK [publish : Change Permissions of the Log Purge Scheduler config File] **************************************************************************************************************
ok: [35.169.196.183] => {"changed": false, "failed": false, "gid": 1005, "group": "crx", "mode": "0644", "owner": "crx", "path": "/mnt/crx/author/crx-quickstart/install/com.adobe.cq.audit.purge.Scheduler-LogPurge.config", "secontext": "user_u:object_r:usr_t:s0", "size": 277, "state": "file", "uid": 1005}

TASK [publish : Pause the execution for cq5 to come up] *********************************************************************************************************************************
Pausing for 300 seconds
(ctrl+C then 'C' = continue early, ctrl+C then 'A' = abort)
Press 'C' to continue the play or 'A' to abort 
fatal: [35.169.196.183]: FAILED! => {"failed": true, "msg": "user requested abort!"}

Но когда я запускаю этот playbook, перезапуск этой службы не вызывается. Почему это так?

Разве мы не можем использовать уведомления в файловых модулях? Любая помощь будет высоко оценена.

1 ответ

Решение

Вы можете прикрепить notify к любому модулю.

Но Ansible будет уведомлять обработчик только тогда, когда задача находится в измененном состоянии - это сделано для того, чтобы предотвратить выполнение ненужных обработчиков (например, перезапуск службы) при последующих запусках playbook.

Ваш журнал выдержки показывают "changed": false для рассматриваемой задачи, поэтому выполнение обработчика не запускается.

Также имейте в виду, что обработчики выполняются в самом конце ролевой книги, если они явно не заполнены мета, поэтому в вашем сценарии обработчик будет выполняться после Pause the execution for cq5 to come up задача.

Другие вопросы по тегам