一、背景

公司业务使用的是一直Oracle数据库,因为多次出现表空间满的时候不能及时发现,每次都是业务组的人员通知处理,这样下来DBA这边就比较被动,所以老大要求监控表空间剩余大小并且当剩余过小时能够及时报警。刚想出来的方案是通过写脚本获取表空间的数据,通脚本中使用expect自动输入密码登陆oracle用户然后再登陆数据库查询数据返回给zabbix_server。但是由于脚本运行时间大概12秒左右,zabbix获取数据总是超时,在网上搜索中发现zabbix插件orabbix,原理是通过orabbix登陆被监控主机oracle数据库,查询数据。个人认为非常好用,包括自定义监控项。唯一的麻烦就是需要在配置文件中添加每一个数据库服务器ip、数据库用户、密码。

二、Orabbix介绍

Orabbix是设计用来为zabbix监控Oracle的数据库的插件,它提供多层次的监控,包括可用性和服务器性能的指标。它提供了从众多Oracle实例采集的有效机制,进而提供此信息的监控和性能指标。然后,您可以利用的zabbix的报告功能为收集的所有数据,并提供分析。目前的发行版中包含了一组预先定义的模板,包括从初始部署报警和图形功能。然而,这些可以进行微调,以满足您额需求和数据/监控要求。

三、Orabbix功能

  • DB Version (i.e. Validity of package)

  • Archiving (Archive log production with trend analysis)

  • Event Waits (Files I/O, single block read, multi-block read, direct path read, SQLNet Messages, Control file I/O, Log Write)

  • Hit Ratio (Hit Ratio on Triggers, Tables/Procedures, SQL Area, Body)

  • Logical I/O (Server performance on Logical I/O of: Current Read, Consistent Read, Block Change)

  • Physical I/O (Redo Writes, Datafile Writes, Datafile Reads)

  • PGA

  • SGA (In particular; Fixed Buffer, Java Pool, Large Pool, Log Buffer, Shared Poolm Buffer Cache)

  • Shared Pool (Pool Dictionary Cache, Pool Free Memory, Library Chache, SQL Area, MISC.)

  • Pin Hit Ratio (Oracle library cache pin are caused by contention with the library cache, the area used to store SQL executables for re-use)

  • Sessions / Processes

  • Sessions (Active Sessions, Inactive Sessions, System Sessions)

  • DBSize/DBFileSize (DBSize size of database really used space and of Filesize)

四、Orabbix的安装配置

其实orabbix只需要安装在一台服务器即可,我就选择安装在Zabbix Server上,当然上面的jdk是为orabbix服务的,因为orabbix就是一个oracle客户端去查找oracle中的数据,然后传给zabbix。

关于JDK的安装可以参加我其他的博文,安装非常简单,这里不再进行介绍。

1、下载Orabbix

建议使用我修改好的软件,下载地址为http://down.51cto.com/data/2337373

  unzip Orabbix-1.2.3.zip
  mv orabbix-1.2.3 /usr/local/orabbix

 

2、调整配置文件

  cd /usr/local/orabbix
  cp init.d/orabbix /etc/init.d/
  chmod +x /etc/init.d/orabbix
  chmod +x /usr/local/orabbix/run.sh

3、创建数据库账号

首先我们需要在被监控的Oracle上面创建一个账号,用于zabbix的数据获取,在oracle的sqlplus里面执行。

  CREATE USER ZABBIX
  IDENTIFIED BY "zabbix"
  DEFAULT TABLESPACE SYSTEM
  TEMPORARY TABLESPACE TEMP
  PROFILE DEFAULT
  ACCOUNT UNLOCK;

  #2 Roles for ZABBIX

  GRANT CONNECT TO ZABBIX;
  GRANT RESOURCE TO ZABBIX;
  ALTER USER ZABBIX DEFAULT ROLE ALL;

  #5 System Privileges for ZABBIX

  GRANT SELECT ANY TABLE TO ZABBIX;
  GRANT CREATE SESSION TO ZABBIX;
  GRANT SELECT ANY DICTIONARY TO ZABBIX;
  GRANT UNLIMITED TABLESPACE TO ZABBIX;
  GRANT SELECT ANY DICTIONARY TO ZABBIX;

如果我们的数据库是Oracle 11g,我们还需要执行下面的语句。

  exec dbms_network_acl_admin.create_acl(acl => 'resolve.xml',description => 'resolve acl', principal =>'ZABBIX', is_grant => true, privilege => 'resolve');
  exec dbms_network_acl_admin.assign_acl(acl => 'resolve.xml', host =>'*');
  commit;

4、配置config.props

config.props是Orabbix的配置文件,路径为/usr/local/orabbix/conf。

  cp config.props.sample config.props

打开配置文件,修改后内容如下:

  #comma separed list of Zabbix servers
  ZabbixServerList=ZabbixServer1

  ZabbixServer1.Address=10.0.0.14
  ZabbixServer1.Port=10051

  #pidFile
  OrabbixDaemon.PidFile=./logs/orabbix.pid
  #frequency of item's refresh
  OrabbixDaemon.Sleep=300
  #MaxThreadNumber should be >= than the number of your databases
  OrabbixDaemon.MaxThreadNumber=100

  #put here your databases in a comma separated list
  DatabaseList=10.0.2.64,10.0.2.63

  #Configuration of Connection pool
  #if not specified Orabbis is going to use default values (hardcoded)
  #Maximum number of active connection inside pool
  DatabaseList.MaxActive=10
  #The maximum number of milliseconds that the pool will wait
  #(when there are no available connections) for a connection to be returned
  #before throwing an exception, or <= 0 to wait indefinitely.
  DatabaseList.MaxWait=100
  DatabaseList.MaxIdle=1

  #define here your connection string for each database
  10.0.2.64.Url=jdbc:oracle:thin:@10.0.2.64:1521:unicode
  10.0.2.64.User=zabbix
  10.0.2.64.Password=zabbix
  #Those values are optionals if not specified Orabbix is going to use the general values
  10.0.2.64.MaxActive=10
  10.0.2.64.MaxWait=100
  10.0.2.64.MaxIdle=1
  10.0.2.64.QueryListFile=./conf/query.props

  #define here your connection string for each database
  10.0.2.63.Url=jdbc:oracle:thin:@10.0.2.63:1521:orcl
  10.0.2.63.User=zabbix
  10.0.2.63.Password=zabbix
  #Those values are optionals if not specified Orabbix is going to use the general values
  10.0.2.63.MaxActive=10
  10.0.2.63.MaxWait=100
  10.0.2.63.MaxIdle=1
  10.0.2.63.QueryListFile=./conf/query.props

备注:

  • ZabbixServerList:可以设置多个,用","进行分割;

  • DatabaseList:可以设置多个被监控的Oracle数据库服务器,用","进行分割,该名称要和zabbix server界面中的Host name保持一致,该配置文件中后续所引用的设定都以该名称为准。

五、启动Orabbix服务

  service orabbix start

六、配置Zabbix添加监控

1、导入模板

模板在软件包的template目录下面,全部导入即可,因为Orabbix版本很老旧了,导入新版的Zabbix可能会出现问题,请大家下载我附件修改好的模板使用。

Configuration-->Templates-->Import

2、Oracle主机添加监控模板

七、验证

参考文档:http://www.smartmarmot.com/wiki/index.php?title=Orabbix

Zabbix通过Orabbix监控Oracle数据库的更多相关文章

  1. Zabbix+Orabbix监控oracle数据库表空间

    Orabbix 是设计用来为 zabbix 监控 Oracle 数据库的插件,它提供多层次的监控,包括可用性和服务器性能指标. 它提供了从众多 oracle 实例采集数据的有效机制,进而提供此信息的监 ...

  2. zabbix利用orabbix监控oracle

    Orabbix 是一个用来监控 Oracle 数据库实例的 Zabbix 插件.(插件安装在zabbix-server端) 下载地址:http://www.smartmarmot.com/produc ...

  3. 【Zabbix】zabora监控Oracle数据库

    zabora监控Oracle数据库 它作为一个开源项目,通过shell脚本有效的监控Oracle基础指标.本文档旨在通过实战,在Zabbix 3.0版本之下,监控生产环境下的多台Oracle数据库. ...

  4. 使用Zabbix监控Oracle数据库

    Orabbix介绍 监控Oracle数据库我们需要安装第三方提供的Zabbix插件,我们先测试比较有名的Orabbix,http://www.smartmarmot.com/product/orabb ...

  5. 利用zabbix监控oracle数据库

    一.概述 zabbix是一款非常强大,同时也是应用最为广泛的开源监控软件,本文将给大家介绍如何利用zabbix监控oracle数据库. 二.环境介绍 以下是我安装的环境,实际部署时并不需要跟我的环境一 ...

  6. orabbix监控oracle

    Orabbix 是一个用来监控 Oracle 数据库实例的 Zabbix 插件.下载地址: http://www.smartmarmot.com/product/orabbix/download/ O ...

  7. Orabbix监控Oracle 11g

    Orabbix简介说明 orabbix是一个用来监控oracle数据库性能的zabbix插件工具,通过安装在被监控服务器上客户端上收集数据并传给zabbix服务器端,然后通过调用图形显示.具有以下功能 ...

  8. 搜索表字段包含某字符串的SQL和监控Oracle数据库的SQL。

    1.第一个SQL 背景:需要找到SQL Server数据库中,包含某个字符串的表,输出表和包含该字符串的列. )='=' --这里填要搜索的字符串 DECLARE @sql NVARCHAR(MAX) ...

  9. 8个DBA最常用的监控Oracle数据库的常用shell脚本

    本文介绍了8个常用的监控数据shell脚本.首先回顾了一些DBA常用的Unix命令,以及解释了如何通过Unix Cron来定时执行DBA脚本.网上也有好多类似的文章,但基本上都不能正常运行,花点时间重 ...

随机推荐

  1. <4>Python切片功能剖析

    引用文章:https://mp.weixin.qq.com/s/NZ371nKs_WXdYPCPiryocw 切片基础法则: (1)公式,禁止0. (2)i, n同号:从序列的第i位索引起,向右取n- ...

  2. matlab练习程序(神经网络识别mnist手写数据集)

    记得上次练习了神经网络分类,不过当时应该有些地方写的还是不对. 这次用神经网络识别mnist手写数据集,主要参考了深度学习工具包的一些代码. mnist数据集训练数据一共有28*28*60000个像素 ...

  3. 前后端分离djangorestframework—— 接入微信模板消息推送

    微信 什么是微信也不多说,跟前面的支付宝一样的 微信支付 微信支付也有个沙箱环境,沙箱环境官方文档 由文档中那句很显眼的话所得,即使是测试环境也需要真实的商户号,所以这个就没法想支付宝那样用沙箱账号来 ...

  4. SQLServer之删除存储过程

    删除存储过程注意事项 在删除任何存储过程之前,请检查依赖对象,并且相应地修改这些对象. 如果没有更新这些对象,则删除存储过程可能会导致依赖对象和脚本失败. 若要显示现有过程的列表,请查询 sys.ob ...

  5. SpringBoot使用注解实现事务管理

    conttoller controller和普通的controller类一样, 不用改变 @RequestMapping(value = "/path/{id}", method ...

  6. SAP CRM Installed Bases(IBase)简介

    SAP CRM使用Installed Base(以下简称IBase)来组织服务相关对象并进行管理.因为我在最近的工作中经常接触这个概念,所以学习了一点相关文档.下面是文档的翻译. 本文链接:https ...

  7. [已决解]关于Hadoop start-all.sh启动问题

    问题一:出现Attempting to operate on hdfs namenode as root 写在最前注意: 1.master,slave都需要修改start-dfs.sh,stop-df ...

  8. adb常用命令(golang版)及输入中文

    package main import ( "crypto/md5" "fmt" "image/png" "io/ioutil&q ...

  9. 路由信息对象Route之属性query和params的区别

    query的使用 第一步:在<router-link/>标签中配置如下 <router-link :to="{name:'beijing',query:{id:1,user ...

  10. JS-数组操作3

    1. 找出数组 arr 中重复出现过的元素 function duplicates(arr) { var result = []; var count = []; for (var i=0;i< ...