Чтобы выполнить автоматизированную задачу на удаленном хосте с помощью Ansible, необходимо заполнить определенные переменные и работать с ними, как и следовало ожидать. Например, этот тип задачи необходим для подключения удаленного хоста, разрешения входа в систему и пользовательских привилегий, а также для настройки среды Python.
Можно подключиться к удаленному хосту по SSH и проверить, соответствует ли хост всем критериям. Однако в качестве инструмента автоматизации Ansible предоставляет модули, которые позволяют выполнять эти утомительные, трудоемкие задачи в одной строке команды.
В этой показано, как использовать встроенный в Ansible модуль ping для выполнения различных заданных переменных на удаленных узлах. Запрос Ansible ping — это простой, но полезный инструмент, который вы можете использовать для проверки доступности и практичности удаленных хостов.
Теперь мы подробнее рассмотрим, как работает Ansible ping.
С учетом этого мы перейдем к представлению модуля ping.
Запрос Ansible ping проверяется на удаленном хосте. Этот модуль специально проверяет:
После отправки запроса ping на удаленный хост модуль возвращает значение, указывающее, был ли ping успешным. По умолчанию модуль ping возвращает строку «pong» в случае успеха и исключение в случае неудачи (если указано).
Модуль ping довольно прост, и ниже приводится список функций, предоставляемых этим модулем:
Теперь мы рассмотрим несколько примеров, в которых используется модуль Ansible ping.
Самый простой способ запустить модуль ping в Ansible — запустить простую команду AD HOC в терминале.
Команда AD HOC выглядит следующим образом:
ansible all -m ping -v
Приведенная выше команда начинается с вызова Ansible, за которым следует конкретный шаблон хоста. В этом случае мы хотим пинговать «all» хосты. Следующая часть, «-m», определяет модуль, который мы хотим использовать. ‘-V’ означает подробный.
В случае успеха вы получите результат, подобный показанному ниже:
Использование /etc/ansible/ansible.cfg в конфигурационном файле 35.222.210.12
Using /etc/ansible/ansible.cfg as config file 35.222.210.12 | SUCCESS => { "ansible_facts": { "discovered_interpreter_python": "/usr/bin/python" }, "changed": false, "ping": "pong" }
Если удаленные хосты недоступны (возможно, они отключены), вы получите результат, подобный показанному ниже:
Использование /etc/ansible/ansible.cfg в конфигурационном файле 35.222.210.12
Using /etc/ansible/ansible.cfg as config file 35.222.210.12
| UNREACHABLE! => { "changed": false, "msg": "Failed to connect to the host via ssh: ssh: connect to host 35.222.210.12 port 22: Connection timed out", "unreachable": true }
Вы также можете использовать модуль ping внутри playbook. В большинстве случаев вы не создадите playbook, который выполняет только ping-запрос. Однако вы можете заключить все задачи в условия запроса ping.
Рассмотрим следующий простой сценарий:
- hosts: all become: yes tasks: - ping
Вы можете заметить, что в приведенном выше сценарии мы включили директиву «become». Это не является обязательным требованием, но мы встречали случаи, когда модуль ping не работал для стандартного пользователя. Теперь вы можете запустить playbook и проверить, соответствует ли хост-сервер требованиям для успешного ответа «pong».
ansible-playbook ping.yml
Если проверка связи не удалась, вы получите следующую ошибку «unreachable»:
fatal: [35.222.210.12]: UNREACHABLE! => {"changed": false, "msg": "Failed to connect to the host via ssh: ssh: connect to host 35.222.210.12 port 22: Connection timed out", "unreachable": true}
Вы также можете указать данные как сбой, чтобы вызвать исключение. Это изменяет возврат по умолчанию с «pong» на «crash».
Рассмотрим следующий сценарий:
- hosts: all become: yes tasks: - ping: crash: data
Запуск playbook с исключением должен вернуть следующее значение:
ansible-playbook ping_except.yml
Эта статья продемонстрировало вам разнообразные возможности модуля ping. Хотя этот модуль не содержит сложных параметров, как большинство модулей Ansible, он все же содержит мощные возможности. Например, вы можете использовать модуль ping, чтобы проверить, не вызвана ли ошибка отсутствующей средой Python, и создать задачу для установки требуемой среды на удаленном хосте.