在zabbix配置自定义脚本监控项实现监控Oracle 数据库alert日志详细步骤

一、背景

使用zabbix监控软件的过程中,很多时候需要运行自定义脚本来实现特定功能,因此需要在zabbix和操作系统上做一些设置。本文详细介绍了zabbix上实现运行自定义脚本监控Oracle 数据库alert日志的过程以及配置预警,自定义执行间隔的详细步骤。

二、步骤

1.写脚本,并赋权可执行

创建check_alert_log.sh文件,脚本如下:

vim check_alert_log.sh

复制代码
#!/bin/bash
alert_dir='/u01/app/oracle/diag/rdbms/'

cd  $alert_dir
alert_log=$(find ./ -name "alert_$ORACLE_SID.log")


tail -n 500 $alert_log | grep -Ei "ORA-|err|fail"

chmod +x check_alert_log.sh

2.zabbix客户端主机修改zaibbix的组权限,root用户执行

usermod -aG oinstall zabbix

3.zabbix客户端主机修改zabbix-agent2配置文件

vim /etc/zabbix/zabbix_agent2.conf

添加如下内容

UnsafeUserParameters=1-----开启自定义参数设置

UserParameter=check_alert_log[*],sh /home/oracle/dbreport/check_log.sh $1---自定义监控项名称,监控项执行脚本命令

4.重启zabbix-agent2客户端

systemctl restart zabbix-agent2.service----重启

systemctl status zabbix-agent2.service---查看状态

5.zabbix配置模板监控项和触发器

创建模板

创建监控项

创建触发器

6.zabbix模板绑定主机

三、结果验证

四、常见报错解决

报错

2025-12-01 16:24:36 sh: /home/oracle/dbreport/check_alert_log.sh: Permission denied

解决方案

1.agent版本

如果使用的是zabbix-agent,只需在agent配置文件中加入AllowRoot=1,重启agent即可。

2.agent2版本

如果使用的是zabbix-agent2,配置文件是没有AllowRoot选项的,为此需要修改服务文件,将User和Group修改为root。

复制代码
[root@ys ~]# cat /usr/lib/systemd/system/zabbix-agent2.service
User=root
Group=root

3.重启agent服务

此时,agent进程是以root身份运行。

重启命令如下

systemctl daemon-reload---重新加载配置

systemctl restart zabbix-agent2.service----重启

最新数据里,获取到的值也恢复正常。

相关推荐
码上上班6 天前
一文学会zabbix
zabbix
乐维_lwops7 天前
利用Zabbix监控指定IP列表的ping
网络·tcp/ip·zabbix
何以不说话14 天前
zabbix部署及nginx的监控
运维·nginx·zabbix
成为你的宁宁14 天前
【Zabbix + 睿象云实现电话告警(附图文教程):从监控项与触发器配置到睿象云电话报警通道部署全流程】
zabbix·电话报警
成为你的宁宁15 天前
【Zabbix 监控 Redis 实战教程(附图文教程):从 Zabbix-Server 部署、Agent2 安装配置到自带监控模板应用全流程】
数据库·redis·zabbix
释怀不想释怀20 天前
Zabbix框架(含相关的面试题)
zabbix
释怀不想释怀21 天前
Zabbix(安装模式)
运维·云原生·zabbix
何以不说话21 天前
记录一下学习日常⑨(ansible、Open-V、zabbix)
学习·ansible·zabbix
成为你的宁宁21 天前
【Zabbix运维监控实战(附图文教程):Nginx 服务可用性、连接请求状态、CPU 内存占用与 JVM(Jar 包 / Tomcat)全维度监控】
运维·jvm·nginx·zabbix
释怀不想释怀22 天前
Zabbix入门介绍和与BMC比较(面试回答)
zabbix