1 创建监控项

概述

要在 Zabbix 前端中创建监控项,请执行以下操作:

  • 前往:数据采集 > 主机
  • 在该主机所在行中单击 监控项
  • 单击屏幕右上角的 创建监控项
  • 在表单中输入监控项参数

您也可以通过打开一个现有监控项,按下 克隆 按钮,然后以其他名称保存来创建监控项。

配置

监控项 选项卡包含监控项的常规属性。

所有必填输入字段都用红色星号标记。

Parameter Description
Name 监控项名称。
支持用户宏
Type 监控项类型。请参见各个监控项类型章节。
Key 监控项键值(最多 2048 个字符)。
支持的监控项键值可在各个监控项类型章节中找到。
同一主机内键值必须唯一。
如果键值类型为 'Zabbix agent'、'Zabbix agent (active)' 或 'Simple check',则键值必须受 Zabbix agent 或 Zabbix 服务器支持。
另请参见:正确的key 格式
Type of information 在执行转换(如有)后,存储到数据库中的数据类型。
Numeric (unsigned) - 64 位无符号整数。
请注意,如果整数监控项接收到浮点值,其小数部分将被截断。
Numeric (float) - 64 位浮点数。
此类型可提供约 15 位精度,范围约为 -1.79E+308 到 1.79E+308(PostgreSQL 11 及更早版本除外)。
也支持接收科学计数法格式的值,例如 1.23E+7、1e308、1.1E-4。
Character - 短文本数据。
Log - 长文本数据,可选带有日志相关属性(timestamp、source、severity、logeventid)。
Text - 长文本数据。另请参见text data limits
Binary - 二进制数(仅支持依赖监控项)。
返回 binary 数据类型值的监控项不支持在计算监控项公式或触发器表达式中使用。
对于仅以某一种特定格式返回数据的监控项键值,会自动选择匹配的 information 类型。
Host interface 选择主机接口。此字段在主机级别编辑监控项时可用。
Units 如果设置了单位符号,Zabbix 会对接收到的监控项值进行后处理,并以指定的单位后缀显示。
支持带特殊格式的单位符号及示例(接收到的监控项值 → 显示值):
B - 字节(1024 → 1 KB)
Bps - 每秒字节数(1024 → 1 KBps)
s - 秒,最多显示三个最大的非零时间单位(881764 → 10d 4h 56m)
uptime - 以 hh:mm:ss 或 N days, hh:mm:ss 格式显示的已运行时间(881764 → 10 days, 04:56:04)
unixtime - Unix 时间戳,格式化为 yyyy.mm.dd hh:mm:ss(881764 → 1970-01-11 04:56:04 AM);要正确格式化,接收到的监控项值必须为 Numeric (unsigned)
对于其他单位(如 Hz、W 等),如果接收到的值超过 1000,则会除以 1000 并显示相应前缀(5000 → 5 KHz,881764 → 881.76 KW)。
如果单位符号前缀为 !,则禁用单位转换和前缀处理(1024 !B → 1024 B,61 !s → 61 s)。
有关单位符号和单位转换的更多示例和详细信息,请参见监控项值后缀
Update interval 每隔 N 秒获取一次该监控项的新值。允许的最大更新间隔为 86400 秒(1 天)。
支持时间后缀,例如 30s、1m、2h、1d。
支持用户宏
单个宏必须填满整个字段。不支持在一个字段中使用多个宏,或将宏与文本混合使用。
注意:只有在存在非零值的自定义间隔时,才能将更新间隔设置为 '0'。如果设置为 '0',且存在非零值的自定义间隔(灵活或计划),则会在自定义间隔持续时间内轮询该监控项。
注意:监控项变为活动状态后或更新间隔变更后,首次轮询可能早于配置值。
新监控项将在创建后 60 秒内进行检查,除非它们具有 Scheduling 或 Flexible 更新间隔且 Update interval 设置为 0。
现有的被动监控项可通过点击 Execute now按钮立即获取值。
Custom intervals 您可以为监控项检查创建自定义规则:
Flexible - 创建 Update interval 的例外(不同频率的间隔)。
Scheduling - 创建自定义轮询计划。
详细信息请参见Custom intervals
Interval 字段支持时间后缀,例如 30s、1m、2h、1d。
支持用户宏
单个宏必须填满整个字段。不支持在一个字段中使用多个宏,或将宏与文本混合使用。
Timeout 设置监控项检查超时时间(适用于受支持的监控项类型)。请选择超时选项:
Global - 使用 proxy/全局超时(显示在灰色的 Timeout 字段中)。
Override - 使用自定义超时(在 Timeout 字段中设置;允许范围:1 - 600s)。支持时间后缀,例如 30s、1m,以及用户宏
点击 Timeouts 链接可配置proxy超时或全局超时(如果未使用 proxy)。请注意,只有具有 Super admin 类型且对 Administration > GeneralAdministration > Proxies 前端部分权限的用户才能看到 Timeouts 链接。
History 请选择以下之一:
Do not store - 不存储监控项历史数据。若只有依赖监控项需要保留历史数据,这对主监控项很有用。
此设置不能被全局 housekeeper 设置覆盖。
Store up to - 指定在数据库中保留详细历史数据的时长(1 小时到 25 年)。较旧的数据将由 housekeeper 删除。以秒为单位存储。
支持时间后缀,例如 2h、1d。支持用户宏
Store up to 的值可在 Administration > Housekeeping 中全局覆盖。
如果存在全局覆盖设置,会显示一个橙色的 信息图标。将鼠标悬停其上时,会显示警告信息,例如 Overridden by global housekeeper settings (1d)
建议尽可能缩短已记录值的保留时间,以减少数据库中值历史记录的大小。您可以将较长的值历史改为存储趋势数据。
另请参见History and trends
Trends 请选择以下之一:
Do not store - 不存储趋势数据。
此设置不能被全局 housekeeper 设置覆盖。
Store up to - 指定在数据库中保留聚合后的历史数据(每小时最小值、最大值、平均值、计数)的时长(1 天到 25 年)。较旧的数据将由 housekeeper 删除。以秒为单位存储。
支持时间后缀,例如 24h、1d。支持用户宏
Store up to 的值可在 Administration > Housekeeping 中全局覆盖。
如果存在全局覆盖设置,会显示一个橙色的 信息图标。将鼠标悬停其上时,会显示警告信息,例如 Overridden by global housekeeper settings (7d)
注意: 非数值数据(character、log 和 text)不支持保留趋势数据。
另请参见History and trends
Value mapping 将值映射应用于此监控项。值映射不会更改接收到的值,仅用于数据显示。
它适用于 Numeric(unsigned)Numeric(float)Character 监控项。
例如,“Windows service states”。
Log time format 仅适用于 Log 类型的监控项。支持的占位符:
yYear (1970-2038)
MMonth (01-12)
dDay (01-31)
hHour (00-23)
mMinute (00-59)
sSecond (00-59)
如果留空,时间戳将被设置为 Unix 时间中的 0,表示 1970 年 1 月 1 日。
例如,考虑 Zabbix agent 日志文件中的以下一行:
" 23480:20100328:154718.045 Zabbix agent started. Zabbix 1.8.2 (revision 11211)."
它以 6 个字符位置的 PID 开头,后面是日期、时间和消息的其余部分。
此行的日志时间格式应为 "pppppp:yyyyMMdd:hhmmss"。
请注意,"p" 和 ":" 字符是占位符,可以是除 "yMdhms" 之外的任何字符。
Populates host inventory field 您可以选择一个主机库存字段,由监控项的值填充。此功能仅在主机启用了自动库存填充时有效。
如果 Type of information 设置为 'Log',则此字段不可用。
Description 输入监控项描述。支持用户宏
Enabled 勾选复选框以启用该监控项,使其被处理。
禁用监控项后,它会立即从历史缓存中移除(日志除外,其最后一个值会被保留)。
Latest data 点击链接查看该监控项的最新数据。
此链接仅在编辑已存在的监控项时可用。

监控项类型相关字段在对应页面中有说明。

在主机级别编辑现有模板级别监控项时,部分字段为只读。 您可以使用表单标题中的链接转到模板级别并在那里编辑这些字段,但请注意,模板级别的更改会影响该模板关联的所有主机上的该监控项。

Tags 选项卡允许定义监控项级别的标签

监控项值预处理

预处理选项卡允许为接收到的值定义转换规则

监控项测试

要执行监控项测试,请确保服务器和 proxy 上的系统时间已同步。 如果服务器时间落后,监控项测试可能会返回错误消息 "The task has been expired." 不过,即使服务器和 proxy 设置了不同的时区,也不会影响测试结果。

可以测试监控项,并在配置正确时返回一个真实值。 即使在监控项保存之前,也可以进行测试。

可测试的对象包括主机和模板监控项、监控项原型以及低级别发现规则。 主动监控项不支持测试。

以下被动监控项类型支持监控项测试:

  • Zabbix agent
  • SNMP agent (v1, v2, v3)
  • IPMI agent
  • SSH checks
  • Telnet checks
  • JMX agent
  • Simple checks (except icmpping*, vmware.* items)
  • Zabbix internal
  • Calculated items
  • External checks
  • Database monitor
  • HTTP agent
  • Script
  • Browser

要测试监控项,请点击监控项配置表单底部的 Test 按钮。 请注意,对于无法测试的监控项(例如主动检查、被排除的简单检查),Test 按钮将被禁用。

监控项测试表单包含所需主机参数的字段(主机地址、端口、使用服务器/proxy 测试(proxy 名称))以及监控项特定的详细信息(例如 SNMPv2 community 或 SNMPv3 安全凭据)。 这些字段具有上下文感知能力:

  • 在可能的情况下会预先填充值,即对于需要 agent 的监控项,会从主机所选的 agent 接口中获取信息。
  • 模板监控项的值必须手动填写。
  • 明文宏值会被解析。
  • 值(或值的一部分)为密钥或 Vault 宏的字段将为空,必须手动输入。 如果任何监控项参数包含密钥宏值,将显示以下警告消息:"Item contains user-defined macros with secret values. Values of these macros should be entered manually."
  • 在当前监控项类型上下文中不需要的字段会被禁用(例如,对于计算型监控项,主机地址字段和 proxy 字段会被禁用)

要测试监控项,请点击 Get value。 如果成功获取到值,它将填充 Value 字段,同时把当前值(如果有)移到 Previous value 字段,并计算 Prev. time 字段,即两个值(点击)之间的时间差;同时还会尝试检测 EOL 序列,并在检测到返回值中存在 "\n\r" 时切换为 CRLF。

点击 Get value and test 可测试预处理。

从主机获取的值和测试结果在发送到前端时会被截断为最大 512KB。 如果结果被截断,会显示一个警告图标。 将鼠标悬停其上时会显示警告说明。 请注意,超过 512KB 的数据仍会被 Zabbix 服务器完整处理。

如果配置不正确,会显示一条错误消息,说明可能的原因。

从主机成功获取的值也可用于测试预处理步骤

表单按钮

表单底部的按钮允许执行多项操作。

添加项目。此按钮仅适用于新项目。
更新项目的属性。
根据当前项目的属性创建另一个项目。
立即执行对新项目值的检查。仅支持被动检查(请参阅更多详细信息)。
请注意,立即检查值时,配置缓存不会更新,因此值不会反映项目配置的最新更改。
通过获取值来测试项目配置是否正确。
删除项目历史记录和趋势。
删除项目。
取消编辑物品属性。

文本数据限制

文本数据限制取决于数据库后端。 在将文本值存储到数据库之前,会先将其截断,以符合数据库值类型限制:

Database Type of information
字符 日志 文本
MySQL 255 characters 65536 bytes 65536 bytes
PostgreSQL 255 characters 65536 characters 65536 characters
SQLite (only Zabbix proxy) 255 characters 65536 characters 65536 characters

自定义脚本限制

可用的自定义脚本长度取决于所使用的数据库:

数据库 字符数限制 字节数限制
MySQL 65535 65535
PostgreSQL 65535 不受限制
SQLite(仅 Zabbix proxy) 65535 不受限制

监控项超时

监控项超时指定 Zabbix 在将检查中止并判定为失败之前应等待多长时间。

当达到超时时间时,即使数据检索尚未完成,检查也会被中止。如果只收到部分数据,则该监控项会变为不受支持,并记录一条错误消息(例如,在 SNMP 检查中,如果多个 OID 里只有一个成功收集到数据)。

对于许多监控项类型,您可以设置灵活的监控项超时:

  • 单个监控项级别
  • 监控项类型级别(在 proxy 级别)
  • 监控项类型级别(在 全局 级别)

如果您希望为某个特定监控项指定更长的超时时间,同时保持其他监控项的超时时间较低,那么按单个监控项设置自定义超时会很有用。

超时优先级

  1. 单个监控项超时会覆盖任何其他超时设置。
  2. proxy 级别的超时会覆盖全局超时。

对于已设置灵活超时的检查,Zabbix 服务器proxy 配置中的超时不起作用。

灵活超时支持

以下监控项类型支持灵活的监控项超时:

不支持的监控项

不支持的监控项会被报告为 不支持 状态,并且仍会按照其标准 更新间隔 重新检查。

如果由于某些原因无法获取监控项的值(例如连接错误、未配置用于处理该监控项的 poller),该监控项就会变为不支持。 此外,未接收到历史数据的监控项会一直保持 不支持 状态。 这是预期行为——只有在收到新的、有效的历史数据时,监控项才会转换为 正常 状态。

与问题一样,不支持的监控项也只会在收到新数据时重新评估——即使该监控项已经没有可用的历史数据。 换句话说,监控项和触发器仅在接收到新数据时才会改变状态。 不过,如果触发器表达式包含 日期和时间 和/或 nodata() 函数,则该触发器会每 30 秒重新计算一次(详情请参见 触发器计算时间)。