ИТ Блог. Администрирование серверов на основе Linux (Ubuntu, Debian, CentOS, openSUSE)

Как использовать модуль Ping в Ansible

Как использовать модуль Ping в Ansible

Чтобы выполнить автоматизированную задачу на удаленном хосте с помощью Ansible, необходимо заполнить определенные переменные и работать с ними, как и следовало ожидать. Например, этот тип задачи необходим для подключения удаленного хоста, разрешения входа в систему и пользовательских привилегий, а также для настройки среды Python.

Можно подключиться к удаленному хосту по SSH и проверить, соответствует ли хост всем критериям. Однако в качестве инструмента автоматизации Ansible предоставляет модули, которые позволяют выполнять эти утомительные, трудоемкие задачи в одной строке команды.

В этой показано, как использовать встроенный в Ansible модуль ping для выполнения различных заданных переменных на удаленных узлах. Запрос Ansible ping – это простой, но полезный инструмент, который вы можете использовать для проверки доступности и практичности удаленных хостов.

Теперь мы подробнее рассмотрим, как работает Ansible ping.

С учетом этого мы перейдем к представлению модуля ping.

 

О модуле Ansible ping

Запрос Ansible ping проверяется на удаленном хосте. Этот модуль специально проверяет:

После отправки запроса ping на удаленный хост модуль возвращает значение, указывающее, был ли ping успешным. По умолчанию модуль ping возвращает строку «pong» в случае успеха и исключение в случае неудачи (если указано).

 

Особенности модуля Ansible ping

Модуль ping довольно прост, и ниже приводится список функций, предоставляемых этим модулем:

 

Как использовать модуль Ansible ping

Теперь мы рассмотрим несколько примеров, в которых используется модуль Ansible ping.

 

Использование команды ping AD HOC

Самый простой способ запустить модуль 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 в Playbooks

Вы также можете использовать модуль 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}

Использование исключения повышения с модулем ping

Вы также можете указать данные как сбой, чтобы вызвать исключение. Это изменяет возврат по умолчанию с «pong» на «crash».

Рассмотрим следующий сценарий:

- hosts: all

become: yes

tasks:
- ping:
crash: data

 

Запуск playbook с исключением должен вернуть следующее значение:

ansible-playbook ping_except.yml

Заключение

Эта статья продемонстрировало вам разнообразные возможности модуля ping. Хотя этот модуль не содержит сложных параметров, как большинство модулей Ansible, он все же содержит мощные возможности. Например, вы можете использовать модуль ping, чтобы проверить, не вызвана ли ошибка отсутствующей средой Python, и создать задачу для установки требуемой среды на удаленном хосте.

Exit mobile version