查看原文
其他

Zabbix利用HTTP代理监控API

Zabbix开源社区 Zabbix开源社区 2022-09-22

马嘉炜 | 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数据格式):

{
  "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,这样可以在链接模版时对不同的主机设置宏变量(用户名密码也可以这样配置)。

————

2022年活动计划,交流会为半天,约50人,免费。期待你的回复,其他选择可至文末留言~



推荐阅读



_

Zabbix 在一位企业资深运维人员眼中,究竟是怎样的存在?—用户分享


_


_

Zabbix全年在线课录屏


_


_

● Zabbix学习资料、客户案例申请(往届峰会ppt)


_


_

● 如何利用Git对Zabbix监控模板进行版本管理及备份?


_


备注“使用Zabbix年限+企业+姓名”

进入交流群,4000+用户已加入

一个人走得快,一群人走得远

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存