Не удалось перезапустить Ansible Service

У меня были некоторые проблемы с перезапуском демона SSH с Ansible.

Я использую последнее программное обеспечение от 11 мая 2015 года (Ansible 1.9.1 / Vagrant 1.7.2 / VirtualBox 4.3.26 / Хост: OS X 10.10.1 / Гость: ubuntu / trusty64)

tl; dr: Кажется, что-то не так с тем, как я вызываю синтаксис службы.

Проблема с оригинальным вариантом использования (обработчик)

сборник пьес

- hosts: all
- remote_user: vagrant
- tasks:

  ...

  - name: Forbid SSH root login
    sudo: yes
    lineinfile: dest=/etc/ssh/sshd_config regexp="^PermitRootLogin" line="permitRootLogin no" state=present
    notify:
      - restart ssh

  ...

- handlers:
  - name: restart ssh
    sudo: yes
    service: name=ssh state=restarted

Выход

NOTIFIED: [restart ssh] 

failed: [default] => {"failed": true}

FATAL: all hosts have already failed -- aborting

Обработчик nginx успешно завершен с почти идентичным синтаксисом.

Задача также не выполняется

сборник пьес

- name: Restart SSH server
  sudo: yes
  service: name=ssh state=restarted

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

Специальная команда также не работает

Ракушка

> ansible all -i ansible_inventory -u vagrant -k -m service -a "name=ssh state=restarted"

инвентарь

127.0.0.1:8022

Выход

127.0.0.1 | FAILED >> {
    "failed": true,
    "msg": ""
}

Командная консоль в коробочных работах

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

> vagrant ssh
> sudo service ssh restart
ssh stop/waiting
ssh start/running, process 7899
> echo $?
0

Командная задача также работает

Выход

TASK: [Restart SSH server] ****************************************************
changed: [default] => {"changed": true, "cmd": ["service", "ssh", "restart"], "delta": "0:00:00.060220", "end": "2015-05-11 07:59:25.310183", "rc": 0, "start": "2015-05-11 07:59:25.249963", "stderr": "", "stdout": "ssh stop/waiting\nssh start/running, process 8553", "warnings": ["Consider using service module rather than running service"]}

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

1 ответ

Решение

Как указано в комментариях выше, это проблема Ansible, которая, очевидно, будет исправлена ​​в выпуске 2.0.

Я просто изменил свой обработчик, чтобы использовать command модуль и перешел на:

- name: restart sshd
  command: service ssh restart
Другие вопросы по тегам