Нельзя выполнять обработчики из ролей зависимостей для всех хостов

Настроить

У меня есть несколько ролей, которые объявляют зависимости ролей и иногда используют обработчики из ролей, от которых они зависят. Упрощенная версия моей установки выглядит следующим образом (это вывод head inventory **/*.yml и он показывает все пути и полное содержимое файлов):

==> inventory <==
[app]
server1 ansible_host=192.168.2.113
[db]
server2 ansible_host=192.168.2.153

==> playbook.yml <==
- hosts: all
  roles:
    - { role: app, when: "inventory_hostname in groups['app']" }
    - { role: db,  when: "inventory_hostname in groups['db']"  }

==> roles/app/handlers/main.yml <==
- name: app handler
  command: echo app handler

==> roles/app/meta/main.yml <==
dependencies: [base]

==> roles/app/tasks/main.yml <==
- command: /bin/true
  notify: [app handler, base handler]

==> roles/base/handlers/main.yml <==
- name: base handler
  command: echo base handler

==> roles/base/tasks/main.yml <==
- command: /bin/true

==> roles/db/handlers/main.yml <==
- name: db handler
  command: echo db handler

==> roles/db/meta/main.yml <==
dependencies: [base]

==> roles/db/tasks/main.yml <==
- command: /bin/true
  notify: [db handler, base handler]

Теперь я бегу ansible-playbook -i inventory playbook.yml что приводит к

PLAY [all] **********************************************************************

TASK [Gathering Facts] **********************************************************
ok: [server1]
ok: [server2]

TASK [base : command] ***********************************************************
skipping: [server2]
changed: [server1]

TASK [app : command] ************************************************************
skipping: [server2]
changed: [server1]

TASK [base : command] ***********************************************************
changed: [server2]

TASK [db : command] *************************************************************
skipping: [server1]
changed: [server2]

RUNNING HANDLER [base : base handler] *******************************************
skipping: [server2]
changed: [server1]

RUNNING HANDLER [app : app handler] *********************************************
changed: [server1]

RUNNING HANDLER [db : db handler] ***********************************************
changed: [server2]

PLAY RECAP **********************************************************************
server1                    : ok=5    changed=4    unreachable=0    failed=0   
server2                    : ok=4    changed=3    unreachable=0    failed=0   

проблема

Моя проблема в том, что я ожидал, что оба сервера выполнят базовый обработчик. Но, по-видимому, он пропущен на сервере2. Если я добавлю -v к ansible команде я получаю бесполезный комментарий, что skipping: [server2] => {"changed": false, "skip_reason": "Conditional result was False"},

Меня также озадачивает то, что базовая роль, кажется, включена дважды, и каждый сервер пропускает одно или другое включение роли соответственно.

Вопрос

  • Можно ли как-нибудь убедиться, что обработчики запущены правильно?

РЕДАКТИРОВАТЬ

  • Это ошибка в том, что обработчик не запущен или это поведение где-то задокументировано?

/РЕДАКТИРОВАТЬ

второстепенные вопросы

  • Есть ли способ объявить зависимости таким образом, чтобы он не приводил к множеству включений, которые выбираются только одним сервером и игнорируются всеми остальными, хотя другие будут включать ту же роль через свои собственные зависимости в какой-то другой точке? Это приводит к большому количеству пропущенных задач, когда у меня есть еще несколько серверов и ролей. (после прочтения документации по включению ролей я подозреваю, что нет)
  • Есть ли другой способ обработки зависимостей ролей и обработчиков с ansible? Я пришел с этой настройкой после прочтения https://medium.com/@ibrahimgunduz34/parallel-playbook-execution-in-ansible-30799ccda4e0

Примечание

Я хотел бы избежать group_by метод, описанный в документации, или, в более общем смысле, выполнение каждой роли в их собственной книге воспроизведения только для правильного набора серверов, потому что у меня много серверов, и я хочу ускорить запуск книги с помощью strategy: free,

0 ответов

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