Zabbix利用HTTP代理监控API

2021-12-20 20:28:34 浏览数 (1)

马嘉炜 | Zabbix开源社区签约专家

  • SRE运维工程师,六年Zabbix监控系统使用经验。在Zabbix架构设计及性能优化领域有丰富的经验,擅长监控模板制作及Zabbix API的二次开发。
  • 官方使用手册《Zabbix标准模板指南》译者

简介

从Zabbix 4.0版本开始,官方提供了一种新的HTTP代理(HTTP agent)的健康方式,通过HTTP协议采集数据,它由Zabbix server或者Zabbix proxy发起,并且不需要安装Zabbix agent。 官方文档说明:https://www.zabbix.com/documentation/current/en/manual/config/items/itemtypes/http 本文将介绍HTTP代理的使用方法及技巧。

环境需求

  • Zabbix 版本 >= 4.0

案例:通过Spring Boot Actuator Web API监控应用状态

  • actuator是spring boot提供的对应用系统的自省和监控的集成功能,可以对应用系统进行配置查看、相关功能统计等。
  • 官方文档说明:https://docs.spring.io/spring-boot/docs/current/actuator-api/htmlsingle/

actuator提供了一个health endpoint用于获取有关应用程序的运行状况的详细信息。 官方文档地址:https://docs.spring.io/spring-boot/docs/current/actuator-api/htmlsingle/#health

URL地址为 http://<ip>:<port>/actuator/health 返回结果(JSON数据格式):

代码语言:javascript复制
{
  "status": "UP",
  "components": {
    "custom": {
      "status": "UP",
      "details": {
        "app": "Alive and Kicking",
        "error": "Nothing! I'm good."
      }
    },
    "diskSpace": {
      "status": "UP",
      "details": {
        "total": 52776349696,
        "free": 43368595456,
        "threshold": 10485760
      }
    },
    "ping": {
      "status": "UP"
    }
  }
}

配置监控项

推荐使用Zabbix的master监控项 依赖监控项(相关项目)来实现一次调用采集多个数据,减少对API的调用次数。

步骤 1: 创建master监控项

创建监控项并修改以下配置:

  • 名称:Get Spring boot actuator health
  • 类型:HTTP代理
  • 键值:spring.boot.actuator.health
  • URL:http://masix.cn:8080/actuator/health(支持使用macro宏变量)
  • 请求类型:GET
  • 要求的状态码:200
  • 信息类型:文本
  • 更新间隔:1m
  • 历史数据保留时长:Do not keep history
  • 应用集:Zabbix raw items

如果API接口需要认证,可以设置HTTP认证用户名密码支持使用macro宏变量。

配置完成后点下方的测试,点击Get value and test,检查是否能够正确获取数据。

步骤 2: 创建依赖监控项(相关项目)

假设需要监控应用的状态以及磁盘的剩余空间这两个指标

指标 1: 监控应用状态

JSONPath语法说明参考官方文档:https://www.zabbix.com/documentation/current/en/manual/config/items/preprocessing/jsonpath_functionality

创建监控项并修改以下配置:

  • 名称:Spring boot Application: Health Status
  • 类型:相关项目
  • 键值:spring.boot.actuator.health.status
  • 主要项:Get Spring boot actuator health
  • 信息类型:字符
  • 应用集:Spring boot Application

进程标签页添加步骤:

  • 名称:JSONPath
  • 参数:$.status
  • Custom on fail: 勾选并选择Set value to,值填写Down(当API无法访问时会将监控项数据设置为Down,方便配置触发器表达式)

点击下方的Test all steps进行配置验证,在中填入master监控项测试获取的数据,点击测试检查是否能够正确获取数据。

指标 2: 监控磁盘剩余空间

创建监控项并修改以下配置:

  • 名称:Spring boot Application: Disk free space
  • 类型:相关项目
  • 键值:spring.boot.actuator.health.diskspace.free
  • 主要项:Get Spring boot actuator health
  • 信息类型:数字(无正负)
  • 单位:B
  • 应用集:Spring boot Application

进程标签页添加步骤:

  • 名称:JSONPath
  • 参数:$.components.diskSpace.details.free
  • Custom on fail: 勾选并选择Discard value(当API无法访问时会将监控项数据丢弃)

点击下方的Test all steps进行配置验证,在中填入master监控项测试获取的数据,点击测试检查是否能够正确获取数据。

检查最新数据能否正常采集

注意:依赖监控项(相关项目)的数据更新间隔是由master监控项设置的更新间隔决定的

至此,监控项的配置就已经完成,接下来可以根据实际情况配置对应的触发器。

在配置模板时,可以将master监控项中的URL配置为macro宏变量,例如: http://{$HOST}:{$PORT}/actuator/health,这样可以在链接模版时对不同的主机设置宏变量(用户名密码也可以这样配置)。

0 人点赞