除了开箱即用的宏supported外,Zabbix还支持用户宏以实现更高的灵活性。
用户宏可以在全局、模板和主机级别定义。这些宏具有特殊语法:
Zabbix按照以下优先级解析宏:
换句话说,如果在一个主机中找不到宏,Zabbix会尝试在主机的各级模板中查找。如果仍未找到,将使用存在的全局宏。
如果在同一级别的多个链接模板中存在同名宏,将使用ID最小的模板中的宏。因此在多个模板中使用同名宏存在配置风险。
如果Zabbix无法找到宏,则该宏不会被解析。
按照设计,配置部分(例如触发器列表)中的宏(包括用户宏)将保持未解析状态,以使复杂配置更加透明。
用户宏可用于:
要定义用户宏,请在前端相应位置进行操作:
全局宏请访问管理 → 常规 → 宏
主机和模板级宏需打开主机或模板属性
and look for the Macros tab
如果在模板的监控项或触发器中使用了用户宏, 建议将该宏添加到模板中——即使已在全局层面定义。 这样当宏类型为文本时,将模板导出为XML并导入其他系统后, 仍能按预期工作。秘密宏的值不会被exported。
用户宏具有以下属性:
参数 | 描述 |
---|---|
Macro | 宏名称。名称必须用花括号包裹并以美元符号开头。 示例:{$FRONTEND_URL}。宏名称允许以下字符:A-Z(仅大写)、0-9、_、. |
Value | 宏值。支持三种值类型: 文本(默认)- 纯文本值 秘密文本 - 值以星号掩码显示,适用于保护密码或共享密钥等敏感信息 Vault机密 - 值包含指向Vault secret的引用路径(格式如'path:key',例如"secret/zabbix:password") 注意:虽然秘密宏的值不可见,但通过监控项的使用可能暴露其值。例如在外部脚本中,引用秘密宏的'echo'语句可能将宏值暴露给前端,因为Zabbix server有权访问真实的宏值。 点击值输入字段末端的按钮选择值类型: ![]() ![]() ![]() ![]() ![]() 用户宏值的最大长度为2048字符(5.2.0之前版本为255字符)。 |
Description | 用于提供该宏更多信息的文本字段。 |
包含秘密宏的URL将无法正常工作, 因为其中的宏会被解析为"******"。
在触发器表达式中,用户宏仅在引用参数或常量时会被解析。 引用一个主机、监控项键、函数、运算符或其他触发器表达式时不会被解析。 秘密宏不能用于触发器表达式。
在"SSH守护进程状态"监控项监控项键值中使用主机级别宏:
net.tcp.service[ssh,,{$SSH_PORT}]
该监控项可分配给多个主机,前提是这些主机上已定义{$SSH_PORT}的值。
在"CPU负载过高"触发器中使用主机级别宏:
last(/ca_001/system.cpu.load[,avg1])>{$MAX_CPULOAD}
此类触发器应在模板上创建,而非在单个主机中编辑。
若需将数值数量作为函数参数使用(例如max(/主机/key,#3)),请在宏定义中包含井号标记,如: SOME_PERIOD => #3
在"CPU负载过高"触发器中使用两个宏:
min(/ca_001/system.cpu.load[,avg1],{$CPULOAD_PERIOD})>{$MAX_CPULOAD}
请注意,宏可以作为触发器函数的参数使用, 在此示例中为min()函数。
将agent不可用状态与监控项update间隔同步:
nodata(/ca_001/agent.ping,{$INTERVAL})=1
集中配置工作时间:
1-5,09:00-18:00
;使用主机原型宏为发现的主机配置监控项:
在一个主机原型上定义用户宏{$SNMPVALUE}并设置
{#SNMPVALUE} low-level discovery macro as a value: