首页
/ Apache APISIX 3.12版本Prometheus监控指标缺失问题分析

Apache APISIX 3.12版本Prometheus监控指标缺失问题分析

2025-05-15 05:44:21作者:胡易黎Nicole

Apache APISIX作为一款高性能的API网关,其内置的Prometheus监控插件为运维人员提供了丰富的监控指标。然而在3.12版本中,部分关键指标如HTTP状态码、延迟和上游服务状态等出现了缺失的情况。

问题现象

在APISIX 3.12版本中,通过访问Prometheus指标端点时,发现缺少了几个重要的监控指标:

  • apisix_http_status(HTTP状态码统计)
  • apisix_http_latency(HTTP请求延迟)
  • apisix_upstream_status(上游服务状态)

这些指标对于监控API网关的健康状况和性能表现至关重要,它们的缺失会严重影响运维人员对系统状态的判断。

问题根源

经过深入分析,发现问题出在Prometheus插件的配置上。在默认配置中,这些指标被设置了过期时间(expire参数),导致它们在收集后不久就被自动清理,无法持续展示。

具体配置如下:

pluginAttrs:
    prometheus:
      export_uri: /apisix/prometheus/metrics
      metric_prefix: apisix_
      default_buckets:
        - 50
        - 100
        - 500
        - 1000
        - 5000
      metrics:
        http_status:
          expire: 600
        http_latency:
          expire: 600
        bandwidth:
          expire: 600
        upstream_status:
          expire: 600

解决方案

解决这个问题的方法很简单:移除这些指标的expire配置项。修改后的配置如下:

pluginAttrs:
    prometheus:
      export_uri: /apisix/prometheus/metrics
      metric_prefix: apisix_
      default_buckets:
        - 50
        - 100
        - 500
        - 1000
        - 5000

技术原理

在APISIX的Prometheus插件实现中,expire参数用于控制指标的保留时间(单位为秒)。当设置为正值时,指标会在指定时间后自动过期并被清理。这种机制原本是为了防止长期不活跃的指标占用内存,但对于核心监控指标来说,这种自动清理行为反而会导致监控数据不完整。

最佳实践

  1. 对于核心监控指标(如HTTP状态码、延迟等),不建议设置expire参数
  2. 对于可能大量产生且非核心的指标,可以考虑适当设置expire值
  3. 定期检查Prometheus指标端点,确保所有关键指标都能正常采集
  4. 在升级APISIX版本时,注意检查监控插件的配置变更

总结

APISIX 3.12版本中Prometheus监控指标的缺失问题,本质上是一个配置问题而非代码缺陷。通过合理配置Prometheus插件,可以确保所有关键监控指标的正常采集和展示。运维人员在部署和升级APISIX时,应当特别注意监控相关的配置项,确保监控系统的完整性和可靠性。

登录后查看全文
热门项目推荐
相关项目推荐

最新内容推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
22
6
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
896
532
KonadoKonado
Konado是一个对话创建工具,提供多种对话模板以及对话管理器,可以快速创建对话游戏,也可以嵌入各类游戏的对话场景
GDScript
21
13
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
7
0
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
85
4
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
372
387
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.09 K
0
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
94
15
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
625
60
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
402
377