При помощи удаленных команд вы можете указать какие из предустановленных команд будут автоматически выполнены на наблюдаемом узле сети при соблюдении некоторых условий.
Таким образом, удаленные команды являются мощным механизмом для умного про-активного мониторинга.
Из наиболее очевидных применений функции вы можете попробовать:
Настройка действий для удаленных команд аналогична настройке действий для отправки сообщений, с той лишь разницей, что вместо отправки сообщения Zabbix будет выполнять команду.
Удаленные команды могут выполняться на стороне Zabbix сервера, прокси или агента. Удаленные команды на Zabbix агенте могут выполняться напрямую Zabbix сервером или через Zabbix прокси. По умолчанию удаленные команды отключены как у Zabbix агента, так и у Zabbix прокси. Их можно включить:
AllowKey=system.run[*]
в конфигурацию агента;Удаленные команды выполняемые Zabbix сервером запускаются как описано в разделе Выполнение команд, включая проверку кода выхода.
Удаленные команды будут выполнены даже если целевой узел сети в обслуживании.
Ограничение длины удаленных команд после раскрытия всех макросов зависит от типа базы данных и заданной кодировки (для хранения не-ASCII символов требуется более одного байта):
База данных | Ограничение в символах | Ограничение в байтах |
MySQL | 65535 | 65535 |
Oracle Database | 2048 | 4000 |
PostgreSQL | 65535 | ограничения нет |
SQLite (только Zabbix прокси) | 65535 | ограничения нет |
Следующее руководство содержит пошаговые инструкции о том, как настроить удаленные команды.
Удаленные команды, которые выполняются на стороне Zabbix агента (пользовательские скрипты) сначала необходимо включить в конфигурации агента.
Убедитесь, что параметр AllowKey=system.run[<команда>,*] добавлен для каждой допустимой команды в конфигурации агента, чтобы разрешить конкретную команду в режиме nowait. Перезапустите демона агента, если изменили этот параметр.
Удаленные команды не работают с активными Zabbix агентами.
Затем, при настройке нового действия в Настройка → Действия:
Все скрипты (вебхук, скрипт, SSH, Telnet, IPMI), которые доступны для операций действий задаются в глобальных скриптах.
Например:
В этом случае, Zabbix попытается перезапустить процесс Apache. Используя эту команду, убедитесь, что она будет выполнена Zabbix агентом (нажмите на Zabbix агент напротив Выполнять на).
Обратите внимание на использование sudo - по умолчанию пользователь Zabbix не имеет прав на перезапуск системных сервисов. Смотрите подсказки ниже о том, как настроить sudo.
Zabbix агент должен быть запущенным на удаленном узле сети и должен принимать входящие подключения. Zabbix агент выполняет команды в фоновом режиме.
Удаленные команды на стороне Zabbix агента выполняются без учета времени ожидания при помощи ключа system.run[,nowait], таким образом результаты выполнения не проверяются. На стороне Zabbix сервера и Zabbix прокси команды выполняются с учетом времени ожидания, указанного в параметре TrapperTimeout в файле zabbix_server.conf или в zabbix_proxy.conf и результаты выполнения проверяются.
Убедитесь, что пользователь 'zabbix' имеет права на выполнение добавленных команд. Один наиболее интересный вариант - использование sudo для предоставления доступа к привилегированным командам. Для настройки доступа, выполните из под root:
Примеры строк, которые можно использовать в файле sudoers:
# разрешение пользователю 'zabbix' выполнения любых команд без пароля.
zabbix ALL=NOPASSWD: ALL
# разрешение пользователю 'zabbix' перезапуска apache без пароля.
zabbix ALL=(ALL) NOPASSWD: /etc/init.d/apache restart
В некоторых системах настройки файла sudoers будут препятствовать не-локальным пользователям выполнять команды. Чтобы это изменить, уберите комментарий с опции requiretty в /etc/sudoers.
Если целевая система имеет несколько интерфейсов выбранного типа (Zabbix агент или IPMI), удаленные команды будут выполнены с использованием интерфейса по умолчанию.
Имеется возможность выполнения удаленных команд через SSH и Telnet с использованием другого интерфейса, отличного от интерфейса Zabbix агента. Доступный интерфейс, который будет использоваться, выбирается в следующем порядке:
* Zabbix агент интерфейс по умолчанию
* SNMP интерфейс по умолчанию
* JMX интерфейс по умолчанию
* IPMI интерфейс по умолчанию
В случае использования удаленных команд через IPMI нужно использовать следующий синтаксис:
где
Примеры глобальных скриптов, которые можно использовать удаленными командами в операциях к действиям.
Перезагрузка Windows при определенном условии.
Для того, чтобы автоматически перезагрузить Windows, когда Zabbix обнаруживает проблемы, задайте следующий скрипт:
Параметр скрипта | Значение |
---|---|
Область | 'Операция действия' |
Тип | 'Скрипт' |
Команда | c:\windows\system32\shutdown.exe -r -f |
Перезагрузка узла сети с использованием управления по IPMI.
Параметр скрипта | Значение |
---|---|
Область | 'Операция действия' |
Тип | 'IPMI' |
Команда | reset |
Выключение хоста с использованием управления по IPMI.
Параметр скрипта | Значение |
---|---|
Область | 'Операция действия' |
Тип | 'IPMI' |
Команда | power off |