1. 环境准备
1.1 系统要求
- oracle 19c数据库服务器
- zabbix服务器(版本5.0或更高)
- zabbix agent 2
1.2 前提条件
- oracle数据库正常运行
- zabbix服务器已安装并配置
- 具有oracle数据库和服务器的管理员权限
2. 安装zabbix agent 2
在oracle数据库服务器上安装zabbix agent 2。
# 添加zabbix仓库 rpm -uvh https://repo.zabbix.com/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm # 安装zabbix agent 2 yum install zabbix-agent2 # 启动服务并设置开机自启 systemctl start zabbix-agent2 systemctl enable zabbix-agent2
3. 配置zabbix agent 2
编辑配置文件 /etc/zabbix/zabbix_agent2.conf
:
server=<zabbix服务器ip> hostname=<本机主机名>
重启zabbix agent 2服务:
systemctl restart zabbix-agent2
4. 创建oracle监控用户
以具有管理员权限的用户(如sys)登录oracle数据库,执行以下sql语句:
-- 创建用户 create user c##zabbix_mon identified by zabbix default tablespace users temporary tablespace temp quota unlimited on users container=all; -- 授予基本权限 grant create session to c##zabbix_mon container=all; grant select any dictionary to c##zabbix_mon container=all; -- 授予特定对象的查询权限 grant select on sys.dba_tablespace_usage_metrics to c##zabbix_mon container=all; grant select on sys.dba_tablespaces to c##zabbix_mon container=all; grant select on sys.dba_users to c##zabbix_mon container=all; grant select on sys.dba_data_files to c##zabbix_mon container=all; grant select on sys.v_$active_session_history to c##zabbix_mon container=all; grant select on sys.v_$archive_dest to c##zabbix_mon container=all; grant select on sys.v_$asm_diskgroup to c##zabbix_mon container=all; grant select on sys.v_$database to c##zabbix_mon container=all; grant select on sys.v_$datafile to c##zabbix_mon container=all; grant select on sys.v_$instance to c##zabbix_mon container=all; grant select on sys.v_$log to c##zabbix_mon container=all; grant select on sys.v_$osstat to c##zabbix_mon container=all; grant select on sys.v_$pgastat to c##zabbix_mon container=all; grant select on sys.v_$process to c##zabbix_mon container=all; grant select on sys.v_$session to c##zabbix_mon container=all; grant select on sys.v_$sysmetric to c##zabbix_mon container=all; grant select on sys.v_$system_parameter to c##zabbix_mon container=all;
5. 配置oracle监控
创建文件 /etc/zabbix/zabbix_agent2.d/oracle.conf
:
plugins.oracle.sessions.cdb1.uri=tcp://localhost:1521 plugins.oracle.sessions.cdb1.user=c##zabbix_mon plugins.oracle.sessions.cdb1.password=zabbix plugins.oracle.sessions.cdb1.service=cdb1
6. 配置环境变量
编辑 /etc/systemd/system/zabbix-agent2.service
文件,在 [service]
部分添加:
environment="oracle_home=/u01/app/oracle/product/19.0.0/dbhome_1" environment="ld_library_path=/u01/app/oracle/product/19.0.0/dbhome_1/lib" environment="path=$path:/u01/app/oracle/product/19.0.0/dbhome_1/bin"
重新加载systemd配置并重启服务:
sudo systemctl daemon-reload sudo systemctl restart zabbix-agent2
7. 在zabbix web界面添加主机
- 登录zabbix web界面
- 进入 configuration -> hosts
- 点击 “create host”
- 填写以下信息:
- host name: <oracle服务器名称>
- groups: 选择适当的主机组
- interfaces: 添加agent接口,填写ip地址和端口(默认10050)
- 在 “templates” 中添加 “template db oracle by zabbix agent 2” 模板
- 在 “macros” 中添加以下宏:
- {$oracle.connstring} = tcp://localhost:1521
- {$oracle.service} = cdb1
- {$oracle.user} = c##zabbix_mon
- {$oracle.password} = zabbix
- 点击 “add” 保存
8. 验证监控
- 进入 monitoring -> latest data
- 选择刚添加的oracle主机
- 查看是否有oracle相关的监控项开始收集数据
9. 常见问题及解决方法
9.1 zabbix agent 2无法连接到oracle
症状:zabbix agent 2日志中出现 “cannot connect to oracle” 错误。
解决方法:
- 检查oracle监听器是否正常运行
- 验证
oracle.conf
中的连接信息是否正确 - 确保防火墙允许zabbix agent 2访问oracle端口(通常是1521)
9.2 ora-00000: dpi-1047错误
症状:出现 “ora-00000: dpi-1047: cannot locate a 64-bit oracle client library” 错误。
解决方法:
- 确保正确设置了oracle_home和ld_library_path环境变量
- 检查oracle客户端库是否为64位版本
- 重新启动zabbix agent 2服务
9.3 权限不足
症状:zabbix无法收集某些oracle指标。
解决方法:
- 检查c##zabbix_mon用户是否有足够的权限
- 可能需要额外授予一些系统视图的select权限
9.4 数据收集延迟
症状:oracle监控数据更新缓慢。
解决方法:
- 检查zabbix服务器和agent的性能
- 调整数据收集间隔
- 优化oracle查询性能
9.5 用户创建失败
症状:创建c##zabbix_mon用户时出错。
解决方法:
- 确保以具有足够权限的用户(如sys)执行创建用户的sql语句
- 检查密码是否符合oracle的密码策略
- 确保在正确的容器中执行命令(如果使用多租户架构)
9.6 表空间问题
症状:用户创建成功但无法使用。
解决方法:
- 确保users和temp表空间存在且有足够空间
- 检查用户的配额设置
10. 结论
通过以上步骤,你应该能够成功配置zabbix来监控oracle 19c数据库。记得定期检查监控数据,及时调整配置以满足不断变化的需求。如遇到其他问题,可查阅zabbix和oracle的官方文档或寻求社区帮助。
注意事项:
- 确保所有密码符合安全策略。
- 定期审查和更新监控用户的权限。
- 保持zabbix和oracle软件的及时更新。
- 根据实际需求调整监控项和触发器。
通过细心配置和及时排障,您可以建立一个可靠的oracle数据库监控系统,为数据库的稳定运行提供有力支持。
以上就是通过zabbix监控oracle 19c数据库的完整配置指南的详细内容,更多关于zabbix监控oracle 19c的资料请关注代码网其它相关文章!
发表评论