首页
/ LibreNMS中Alert History无数据显示问题的分析与解决

LibreNMS中Alert History无数据显示问题的分析与解决

2025-06-15 10:12:11作者:邓越浪Henry

问题现象

在LibreNMS监控系统中,用户发现"Alerts > Alert History"页面无法显示任何告警历史记录,即使数据库中确实存在相关数据。通过直接访问数据库或使用curl命令绕过前端界面可以获取到数据,这表明问题出在前端与后端的交互环节。

技术分析

经过深入排查,发现问题根源在于前端请求参数传递异常。具体表现为:

  1. 当用户访问Alert History页面时,前端通过ajax_table.php发起POST请求获取数据
  2. 无论用户是否设置过滤条件,请求中都会强制包含device_id=0参数
  3. 后端接收到device_id=0的请求后,会过滤掉所有非0设备的告警记录
  4. 由于实际设备ID都不为0,导致查询结果为空

解决方案

开发团队已定位问题出在alert-log.inc.php文件中,并修复了参数传递逻辑。修复后的版本中:

  1. 当用户未设置设备过滤条件时,不再默认添加device_id=0参数
  2. 后端接收到无device_id参数的请求时,会返回所有设备的告警记录
  3. 只有当用户明确选择特定设备过滤时,才会添加对应的device_id参数

影响范围

该问题不仅影响Alert History功能,类似的问题也存在于Alerts > Notifications页面,因为该页面同样会默认发送alert_id=0参数。

验证方法

用户可以通过以下curl命令验证问题:

# 有问题的请求(包含device_id=0)
curl 'https://example.com/ajax_table.php' -X POST --data-raw 'current=1&rowCount=50&sort[time_logged]=desc&searchPhrase=&id=alertlog&device_id=0&state=-1&min_severity='

# 正常工作的请求(移除device_id参数)
curl 'https://example.com/ajax_table.php' -X POST --data-raw 'current=1&rowCount=50&sort[time_logged]=desc&searchPhrase=&id=alertlog&state=-1&min_severity='

升级建议

遇到此问题的用户应:

  1. 升级到最新版本的LibreNMS
  2. 运行验证脚本确保系统完整性
  3. 清除浏览器缓存后重新测试功能

该修复已包含在LibreNMS的后续版本中,用户只需保持系统更新即可获得修复。

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