首页 技术 正文
技术 2022年11月21日
0 收藏 543 点赞 4,074 浏览 2478 个字

文章转载自:http://mp.weixin.qq.com/s?__biz=MzA3MzYwNjQ3NA==&mid=2651296856&idx=1&sn=2bdf780719d3bd913f80ebab18ada237&scene=23&srcid=0719KBxswRECyHXV3DbvSgSS#rd

在这里本人只是作为好的文章储存,不做他用

原创 2016-07-19 南非蜘蛛 运维帮

上次写完《 Zabbix用好LLD,立马感觉高大上许多》后,近期又遇到一个用 Zabbix 监控 Oracle 的需求,有一些心得体会,记录一下以备后用。

这次还是用到了 Zabbix 的 LLD 功能,这个功能可谓是:无 LLD 不 Zabbix ,强大到让人想哭。

一、Orabbix 和 Zabora 的问题

一开始用 Orabbix 监控 Oracle,这个插件的工作模式是配置好实例信息,然后起一个JAVA程序,这个进程会根据定义好的查询语句获取到数据,用Trapper模式发送给 Zabbix 收集并展现。

但是用 Orabbix 监控 Oracle 存在几个问题:

1、JAVA程序需要 JRE 环境,但实际情况是:并不是所有机器都安装了JRE。

2、每个实例都需要在 Zabbix 里配置一个HOST,这是一个非人性化的设计。

3、Orabbix 不在 Zabbix 框架内,不受 Zabbix 统一管理,要想升级、配置的话都麻烦要死。

4、不能自动发现实例的所有表空间,我们非常需要这个功能。

5、最可怕的是网上的好多中文文档全有问题,走了很多弯路。

用了一段 Orabbix 时间后,果断放弃,目光转向了 Zabora 插件,这是用 Shell 写的,Zabora 设计思路还可以,不过写的有点简陋,也不能满足我的需求。有兴趣的朋友可以在全球最大的同性交友网站github上搜索:zabora

所以,我打算重新造这个轮子。

二、监控 Oracle 的需求

1、可以自动发现所有数据库实例并监控

2、可以自动发现所有数据库实例里的表空间,监控大小及使用率

3、可以灵活扩展监控选项

4、可以方便升级(如果在zabbix框架里,我已经实现里自动升级功能)

三、设计及功能详解

首先来看一个 Oracle 数据库的架构,和我们常用的MySQL有一点不一样。

在一个数据库里可以有多个实例,每个实例下面包括多个用户和多个表空间。

<img src="https://img.zhankr.net/yqgvvxvt0b4286185.jpg" data-ratio="1.0341726618705036" data-w="" />
zabbix 用 LLD 完全自动化监控 Oracle

我们最终要监控的 item 至少应该知道以下几个信息:

实例名字、数据库用户名、数据库密码、管理数据库的操作系统用户及环境文件,如果要监控表空间,还需要表空间的名字。

听起来还是比较晕的,下面我来梳理一下这些信息。

四、几个主要程序的作用:

1) key.conf 文件中定义了4个key

zabbix 用 LLD 完全自动化监控 Oracle

<img src="https://pic.ikafan.com/imgp/L3Byb3h5L2h0dHAvbW1iaXoucXBpYy5jbi9tbWJpei90emlhNGJjWTVIRUsyVDdYbDdyWjJSSW5LdkltSlNXTHBnOXBpYlJpY1Bac2ozQ2drZ2xRVnFjelpUaWNraWJUekNnNzBaZ3B2c1lCeFFJeHd6a3lCbUlWWHFRLzA/d3hfZm10PXBuZw==.jpg" data-ratio="0.08633093525179857" data-w="" />

第一个key用来发现有几个实例

第二个key用来获取实例里需要监控的值

第三个key用来发现所有实例里所有的表空间

第四个key用来获取表空间的大小和使用率

2) oracle.conf 定义了实例的基本信息

zabbix 用 LLD 完全自动化监控 Oracle

<img src="https://img.zhankr.net/qyqskcxgli4286188.png" data-ratio="0.5413669064748201" data-w="" />
其实也可以没有这个文件,但是需要满足一些条件,完全做到关联模板就自动发现并监控。

但是需要两个条件,有兴趣的朋友可以试试:

  • 用程序发现所有实例及运行实例的用户,这个简单

    ps -ef|grep smon|grep -v grep|awk ‘{print $8}’|awk -Fora_smon_ ‘{print $2}’

  • 为 Zabbix 在所有数据库里创建统一的监控账号和密码,然后在获取数据里的shell定义或者从Zabbix web传参给获取数据的shell也行。

3、discover_oracle_db.sh

发现所有实例并输出JSON格式数据给Zabbix

4、discover_oracle_tb.sh

发现所有实例及表空间并输出JSON格式数据给Zabbix

5、sql目录下的*.sql

sql目录下的所有sql文件都是用到的执行语句,所以在shell里你看不到具体的执行语句,都是调用的这里的,在shell里的调用语法大概都是这样:

sqlplus -s ${DB_USER}/${DB_PASS} @/etc/zabbix/zabbix_agentd.d/script/sql/xxxxx.sql

如果你需要扩展监控,还需要添加一个对应的sql语句

五、在Zabbix Web里配置监控项

1、添加两个自动发现,一个数据库实例自动发现,一个数据库表空间自动发现。

2、添加需要监控的item及trigger等

六、Latest data里的效果

三个Applications分组

zabbix 用 LLD 完全自动化监控 Oracle

所有实例里的监控项

zabbix 用 LLD 完全自动化监控 Oracle

所有实例里所有表空间的使用率

zabbix 用 LLD 完全自动化监控 Oracle

 

理论上这套架构设计可以满足多数据库实例(单实例,集群实例)、多表空间的自动发现及监控需求。

代码我需要整理一下发布,因我不太懂Oracle,谁要是很懂,可以帮我写一些oracle监控语句,我丰富一下监控项,加我微信yunweibang008

在此感谢搜狐畅游的杨建荣同学,他也是业内知名 Oracle 专家,帮我贡献了很多Oracle sql语句,下面是他的个人订阅号,有很多干货,值得关注。

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,077
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,552
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,400
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,176
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,813
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,894