2 远程命令

概述

使用远程命令,您可以预定义在某些情况下会在受监控主机上自动执行的命令。

因此远程命令是智能主动监控的强大机制。

在该功能最显而易见的用途中,你可以尝试:

  • 自动重启某些没有响应的应用(web服务器、中间件、CRM)

  • 使用IPMI 'reboot'命令重启某些确实无法响应的服务器。

  • 磁盘空间不足时自动释放(删除旧文件、清理)

  • 根据CPU负载将VM从一台物理机迁移到另一台

  • CPU(磁盘、内存或其他)资源不足时向云环境添加新节点

为远程命令配置操作与发送消息类似,唯一的区别是 Zabbix 将执行一个命令而不是发送消息。

远程命令可以由Zabbix Server、Proxy 或agent执行。Zabbix agent上的远程命令可以由Zabbix Server或通过 Proxy 执行。Zabbix agent和Zabbix Proxy上的远程命令默认都是禁用的。 它们可以通过以下方式启用:

  • 在agent的配置中添加一个AllowKey=system.run[*] 参数;

  • 在代理的配置中将EnableRemoteCommands参数设为‘1’。

由 Zabbix server执行的远程命令按照命令执行所述运行,包括退出代码检查。

即使目标主机在维护状态,远程命令也会执行。

远程命令限制

解析所有宏之后远程命令的限制取决于数据库和字符集(存储非 ASCII 字符需要一字节以上):

数据库 字符限制 字节限制
MySQL 65535 65535
Oracle Database 2048 4000
PostgreSQL 65535 not limited
SQLite (only Zabbix proxy) 65535 not limited

以下教程提供了设置远程命令的分步指导。

配置

在 Zabbix agent上执行远程命令(自定义脚本)必须先在agent配置中启用。

必须确保添加了AllowKey=system.run[*]参数,并重启 agent后台驻留程序。

Zabbix active agent上远程命令不不生效。

然后,在告警 → 动作 → 告警动作配置新动作时:

  • 定义适当的条件。在本例中,设置动作由Apache的任何灾难问题激活:

  • Operations选项卡,在Operations/Recovery/Update的操作块里点击
  • 从Operation下拉菜单选择一个预定义的脚本

  • 为脚本选择目标列表

预定义脚本

动作可用的所有脚本(webhook,、脚本、SSH、Telnet、IPMI) 定义在 全局脚本

例如:

sudo /etc/init.d/apache restart 

此例中,Zabbix会尝试重启一个Apache进程。确保这个命令在Zabbix agent上执行(点击Zabbix agent按钮为Execute on)。

注意sudo的用法——Zabbix用户默认没有权限重启系统服务 。请查看以下关于配置sudo的提示。

从 Zabbix agent 7.0 开始,远程命令也可以在以主动模式运行的 agent 上执行。Zabbix agent - 无论是主动还是被动都可以在远程主机上运行,​​并在后台执行命令。

Zabbix agent上的远程命令由system.run[,nowait]键执行时没有timeout,并且不检查执行的结果。在Zabbix Server 和Zabbix Agent上,远程命令执行时有timeout,在zabbix_server.conf或zabbix_proxy.conf文件里配置TrapperTimeout参数,并且检查 执行的结果。

访问权限

确保‘zabbix’用户拥有执行配置的命令的权限。用户可能有兴趣使用sudo给特权命令访问权限。要配置访问权限,用root执行以下命令:

# visudo

可以在sudoers文件使用示例的几行:

# allows 'zabbix' user to run all commands without password.
       zabbix ALL=NOPASSWD: ALL
       
       # allows 'zabbix' user to restart apache without password.
       zabbix ALL=NOPASSWD: /etc/init.d/apache restart

在有些操作系统中,sudoers文件禁止非本地用户执行命令,可以在/etc/sudoers文件中取消注释requiretty选项。

有多个接口的远程命令

如果目标系统有多个所选类型(Zabbix agent或IPMI)的接口,远程命令会在默认的接口执行。

除Zabbix agent接口以外,可以在其它接口通过SSH或Telnet执行远程命令。可用的接口按如下顺序选择:

  • Zabbix agent default interface
  • SNMP default interface
  • JMX default interface
  • IPMI default interface

IPMI远程命令

对于IPMI远程命令应使用如下语法:

<command> [<value>]

其中

  • <command>——表示一个没有空格的IPMI命令。
  • <value>——其值为'on'、'off' 或任何无符号整数,<value> 是可选参数。

示例

可能在动作的操作中使用的全局脚本的示例。

示例 1

在特定条件下重启Windows。

为了根据Zabbix检测到的问题自动重启Windows,定义如下脚本:

脚本参数
范围 'Action operation'
类型 'Script'
命令 c:\windows\system32\shutdown.exe -r -f
示例 2

用 IPMI控制重启主机。

脚本参数
范围 'Action operation'
类型 'IPMI'
命令 reset
示例 3

使用 IPMI控制关闭主机电源。

脚本参数
范围 'Action operation'
类型 'IPMI'
命令 power off