【Zabbix】zabora监控Oracle数据库
时间:2019-10-23
本文章向大家介绍【Zabbix】zabora监控Oracle数据库,主要包括【Zabbix】zabora监控Oracle数据库使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
zabora监控Oracle数据库
它作为一个开源项目,通过shell脚本有效的监控Oracle基础指标。本文档旨在通过实战,在Zabbix 3.0版本之下,监控生产环境下的多台Oracle数据库。
建立oracle账号
CREATE USER monitor IDENTIFIED BY 'xxxxxxx' DEFAULT TABLESPACE SYSTEM TEMPORARY TABLESPACE TEMP PROFILE DEFAULT ACCOUNT UNLOCK;
GRANT CONNECT TO monitor;
GRANT RESOURCE TO monitor;
ALTER USER monitor DEFAULT ROLE ALL;
GRANT SELECT ANY TABLE TO monitor;
GRANT CREATE SESSION TO monitor;
GRANT SELECT ANY DICTIONARY TO monitor;
GRANT UNLIMITED TABLESPACE TO monitor;
GRANT SELECT ANY DICTIONARY TO monitor;
GRANT SELECT ON V_$SESSION TO monitor;
GRANT SELECT ON V_$SYSTEM_EVENT TO monitor;
GRANT SELECT ON V_$EVENT_NAME TO monitor;
GRANT SELECT ON V_$RECOVERY_FILE_DEST TO monitor;
基本原理
它的核心是通过一个zabora.sh
脚本,调用zabora/sql
目录下的多个sql脚本,用于获取json数据。然后在zabbix平台上调用。用于监控。
部署命令:
./zabora/deploy_zabbix.sh "${ORACLE_USER}" "${ORACLE_PASS}"
chmod 755 /etc/zabbix/scripts/agentd/zabora/zabora.sh
如上命令,可以直接部署zabora.sh
脚本。效果如下:
配置了
/etc/zabbix/zabbix_agentd.d/zabora.conf
。放置shell脚本,SQL脚本到
/etc/zabbix/scripts/agentd/zabora
目录下。UserParameter=zabora[*],/etc/zabbix/scripts/agentd/zabora/zabora.sh -o $1 -s $2 -a $3 UserParameter=zabora.discovery[*],/etc/zabbix/scripts/agentd/zabora/zabora.sh -o $1 -s $2 -a $3 -j $4 UserParameter=zabora.version,/etc/zabbix/scripts/agentd/zabora/zabora.sh -v short
这里手工调用
zabora.sh
,查看其机理。-o
代表oracle的sid-s
代表调用sql脚本的简称。-j
是否以json串的结果输出。以下是查看Oracle表空间的信息。
[root@oradb sql]# /etc/zabbix/scripts/agentd/zabora/zabora.sh -o oradb -s tb_list -j 1 { "data":[ { "{#1}":"SYSTEM" }, { "{#1}":"SYSAUX" }, { "{#1}":"USERS" }, { "{#1}":"OD" }, { "{#1}":"OA" }, { "{#1}":"FA" }, { "{#1}":"HR" }, { "{#1}":"IPC_HZ_DB" }, { "{#1}":"PM" }, { "{#1}":"DEF3DB" }, { "{#1}":"HDOA" }, { "{#1}":"ARP" }, { "{#1}":"LMS_MANAGE" }, { "{#1}":"LMS_SERVER" }, { "{#1}":"DEVPLATFORM" }, { "{#1}":"NEWOA" }, { "{#1}":"PAY" }, { "{#1}":"WHIOV_OA" }, { "{#1}":"TBS_OA" }, { "{#1}":"FIN" }, { "{#1}":"EXCHANGE" }, { "{#1}":"PLATFORM" }, { "{#1}":"NNC_DATA02" }, { "{#1}":"NNC_DATA03" }, { "{#1}":"NNC_INDEX01" }, { "{#1}":"NNC_INDEX02" }, { "{#1}":"NNC_INDEX03" }, { "{#1}":"PORTAL" }, { "{#1}":"NNC_DATA01" }, { "{#1}":"FINEDB" }, { "{#1}":"ARP_FLASH_ARC" }, { "{#1}":"FINEDB51" } ] }
在server端,测试脚本的可用性.
[root@localhost ~]# zabbix_get -s 172.31.222.34 -k "zabora[oradb,db_active,1]" 1 [root@localhost ~]# zabbix_get -s 172.31.222.34 -k "zabora[oradb,tb_size,SYSTEM]" 3.43
以上说明,后台server端和agent端,脚本配置无误。现在可以配置前台,用于监控oracle的相关指标。
zabbix前台配置
步骤1,导入模板
选择template_db_oracle-2.2.xml这个模板,【配置】--》【模板】--》【导入】,模板导入成功。
模板的内容,无非就是监控项,触发器,图形等。其实可以自己建立一个监控指标,用于监控。
步骤2,添加主机到模板中。
【配置】--》【主机】。选择你要监控的Oracle主机。
【模板】,添加需要链接的模板,这里的模板名字为【Template_DB_Oracle】。
【主机】--》【宏】。用于配置{$ORACLE_SID}的参数值。效果如下:
{$ORACLE_SID} = oradb。
最终效果
原文地址:https://www.cnblogs.com/zhangshengdong/p/11725299.html
- Excel导出工具类.
- POI -纯java代码实现导出excel表格
- 程序员必知的8大排序(java实现)
- Struts2 s2-032远程代码执行分析
- 微信企业号二次开发--自定义菜单接口开发--应用中心
- 微信最新自定义菜单事件
- 微信JSSDK分享到朋友圈和朋友自定义内容功能实现
- 无线安全渗透测试套件WiFi-Pumpkin新版本发布
- Java使用QQ邮箱给其他邮箱发邮件
- 从wireshark抓包开始学习https
- 用于时间序列预测的Python环境
- Pandoc安装实现Markdown转PDF (CentOS6)
- String类replaceAll方法正则替换深入分析
- 微信硬件平台对接--蓝牙
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 手把手教你使用yolo进行对象检测
- K8s之Helm工具详解
- 技术创作101训练营——上古神器Gvim--从入门到精通
- 关于linux7下编写crontab任务执行mysqldump备份无效
- 黑暗中的YOLO:解决黑夜里的目标检测 | ECCV 2020
- Elasticsearch:Java 运用示例
- 【5分钟玩转Lighthouse】搭建个人云盘
- Elasticsearch:Index alias
- 编程神器来了!写代码、搜问题,全部都在「终端」完成!是时候入手了
- Array - 238. Product of Array Except Self
- Array - 209. Minimum Size Subarray Sum
- Array - 334. Increasing Triplet Subsequence
- Array - 123. Best Time to Buy and Sell Stock III
- Array - 122. Best Time to Buy and Sell Stock II
- Array - 121. Best Time to Buy and Sell Stock