当前位置: 首页 > news >正文

zabbix平台无法删除已停用主机的处理案例

在zabbix平台上删除已停用的主机,提示“SQL描述式执行已失败: "DELETE FROM items WHERE (itemid IN (.....)”,无法删除,本文为处理情况。

一、问题现象

在zabbix平台上删除已停用的主机,提示“SQL描述式执行已失败: "DELETE FROM items WHERE (itemid IN (.....)”,无法删除。弹出信息如下:

 弹窗信息为:

SQL描述式执行已失败: "DELETE FROM items WHERE (itemid IN ('46182','46183','46184','46185','46186','46187','46188','46189','48350','48351','48352','48353','48354','48355','48356','48357','48358','48359','48360','48361','125078','125079','125080'))"

    Undefined array key "messages" [zabbix.php:17 → require_once() → ZBase->run() → ZBase->initMessages() in include/classes/core/ZBase.php:530]
foreach() argument must be of type array|object, null given [zabbix.php:17 → require_once() → ZBase->run() → ZBase->initMessages() in include/classes/core/ZBase.php:530]

 二、问题处理

1、尝试先将主机关联的模板删除

尝试先将主机关联的模板删除,保存时出下以下问题弹窗:

 信息内容如下:

    pg_query(): Query failed: ERROR:  update or delete on table "items" violates foreign key constraint "c_functions_1" on table "functions"
DETAIL:  Key (itemid)=(48351) is still referenced from table "functions". [zabbix.php:17 → require_once() → ZBase->run() → ZBase->processRequest() → CController->run() → CControllerHostUpdate->doAction() → CApiWrapper->__call() → CFrontendApiWrapper->callMethod() → CApiWrapper->callMethod() → CApiWrapper->callClientMethod() → CLocalApiClient->callMethod() → CHost->update() → CHost->updateForce() → CHostGeneral->updateTemplates() → CHostGeneral::unlinkTemplatesObjects() → CDiscoveryRule::clearTemplateObjects() → CDiscoveryRule::deleteForce() → CDiscoveryRule::deleteAffectedItemPrototypes() → CItemPrototype::deleteForce() → CItemPrototype::deleteDiscoveredItems() → CItem::deleteForce() → DB::delete() → DBexecute() → pg_query() in include/db.inc.php:255]
Error in query [DELETE FROM items WHERE (itemid IN ('46182','46183','46184','46185','46186','46187','46188','46189','48350','48351','48352','48353','48354','48355','48356','48357','48358','48359','48360','48361','125078','125079','125080'))] [ERROR:  update or delete on table "items" violates foreign key constraint "c_functions_1" on table "functions"
DETAIL:  Key (itemid)=(48351) is still referenced from table "functions".]

可以看到这个错误的核心原因是:你要删除的items表中的记录('46182','46183','46184','46185','46186','46187','46188','46189','48350','48351','48352','48353','48354','48355','48356','48357','48358','48359','48360','48361','125078','125079','125080')被functions表通过外键约束c_functions_1引用了。数据库的外键约束会阻止删除 “被依赖” 的记录,以保证数据完整性。

三、解决办法

需要先删除functions表中引用了相关itemid的依赖记录,再删除items表中的目标记录。具体步骤如下:

1、查看functions表中依赖的记录

首先登录 Zabbix 数据库(PostgreSQL),执行以下 SQL 查询,找到报错itemid清单的记录:

SELECT * FROM functions WHERE itemid in ('46182','46183','46184','46185','46186','46187','46188','46189','48350','48351','48352','48353','48354','48355','48356','48357','48358','48359','48360','48361','125078','125079','125080');

执行后会返回functions表中所有关联这些itemid的记录(这些记录是导致删除失败的直接原因)。

2、 删除functions表中的依赖记录

根据上一步查询到的结果,删除这些依赖记录

zabbix=# DELETE FROM functions WHERE functionid IN (SELECT functionid FROM functions WHERE itemid in ('46182','46183','46184','46185','46186','46187','46188','46189','48350','48351','48352','48353','48354','48355','48356','48357','48358','48359','48360','48361','125078','125079','125080'));
DELETE 37
zabbix=# 
 3、再次删除主机

从界面再次删除主机,可以看到主机已正常删除。

四、注意事项

1、操作前备份

删除数据库记录有风险,建议先备份 Zabbix 数据库(尤其是itemsfunctions表),避免误删数据。

2、理解业务含义

functions表存储的是 Zabbix 中与监控项相关的 “函数”(如计算方式、触发器表达式中引用的函数等),删除这些记录会影响依赖它们的触发器、图形等,需确认这些关联内容已不再需要。

3、优先通过 Zabbix 界面操作

尽量通过 Zabbix 前端界面(而非直接数据库操作)删除监控项,界面会自动处理部分关联依赖(但复杂场景可能仍需手动处理)。

按以上步骤处理后,即可解决外键约束导致的主机删除失败问题。

http://www.lryc.cn/news/606762.html

相关文章:

  • 【华为机试】127. 单词接龙
  • Spring Boot + MongoDB:从零开始手动配置 MongoConfig 实战
  • SAM2 : Segment Anything in Images and Videos
  • 神经网络的基础
  • 【前端】CSS Flexbox布局示例介绍
  • CSS组件化样式新篇章:@scope
  • SystemVerilog的系统函数和任务
  • 无图形界面的CentOS 7网络如何配置
  • 【0基础PS】PS工具详解--仿制图章工具
  • OpenGL Camera
  • socket编程-UDP(2)-设计翻译系统
  • 中英混合的语音识别XPhoneBERT 监督的音频到音素的编码器结合 f0 特征LID
  • 【LeetCode】算法详解#11 ---相交链表
  • 《Java 程序设计》核心知识点梳理与深入探究
  • 深入理解C语言指针:从回调函数到数组指针笔试题全解析(下)
  • Canny边缘检测算法-个人记录
  • 【世纪龙科技】3D交互深度赋能-汽车整车维护仿真教学软件
  • 汽车供应链PPAP自动化审核指南:如何用AI实现规则精准匹配与文件智能校验
  • 【世纪龙科技】汽车整车维护仿真教学软件-智构整车维护实训
  • 目标检测检出率,误检率,ap,map等评估python代码
  • 防火墙安全策略实验一
  • 分类预测 | Matlab实现CPO-PNN冠豪猪算法优化概率神经网络多特征分类预测
  • Redis学习-----Redis的基本数据类型
  • 数学与应用数学的区别是什么
  • CSS font-weight:500不生效
  • Mysql join语句
  • 智慧能源管理平台的多层协同控制架构研究
  • ansible 在EE 容器镜像中运行
  • 在SQL SERVER 中,用SSMS 实现存储过程的每日自动调用
  • 守护数字核心:主机安全的重要性与全方位防护指南