一、Orabbix简介

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

二、Orabbix监控的内容

1、数据库版本

2、归档日志与生产趋势

3、触发器,表/过程命中率

4、逻辑IO性能

5、物理IO性能

6、PGA

7、SGA

8、共享池

9、Session

10、数据库大小

 三、服务端操作

1、安装jre。(确保有Java的环境)

下载地址:http://www.oracle.com/technetwork/java/javase/downloads/

# rpm -ivh jre-7u67-linux-x64.rpm

Preparing... ########################################### [100%]

1:jre ########################################### [100%]

Unpacking JAR files...

rt.jar...

jsse.jar...

charsets.jar...

localedata.jar...

jfxrt.jar...

2、安装orabbix (一般选择安装在zabbix server端,如果安装在其他地方也可以)

下载地址:http://www.smartmarmot.com/product/orabbix/download/

1)在/opt创建目录创建orabbix文件。(原因:orabbix启动文件默认写在/opt/orabbix目录下,也可以修改一下orabbix启动脚本的路径 )

#mkdir /opt/orabbix

#mv orabbix-1.2.3.zip /opt/orabbix

#cd /opt/orabbit

#unzip orabbix-1.2.3.zip

2)授予文件可执行的权限

#chmod a+x /opt/orabbix -R

3)创建一个名为config.props文件,有模板可以参考。

#cp /opt/orabbix/conf/config.props.sample config.props

4)修改confi.props配置文件,仅需修改如下内容即可。

参数说明:

# cat /opt/orabbix/conf/config.props |grep -v "#"   这里仅取没有注释的。

ZabbixServerList=ZabbixServer          #zabbix名称

ZabbixServer.Address=192.168.0.119     #zabbix服务端的IP地址

ZabbixServer.Port=10051                #zabbix服务端的端口

OrabbixDaemon.PidFile=./logs/orabbix.pid

OrabbixDaemon.Sleep=300

OrabbixDaemon.MaxThreadNumber=100

DatabaseList=twstcptest.com    #这个名称可以随便起,但是必须跟监控的主机名保持一致。

DatabaseList.MaxActive=10

DatabaseList.MaxWait=100

DatabaseList.MaxIdle=1

twstcptest.com.Url=jdbc:oracle:thin:@192.168.0.110:1521:rdcms  #这里主要是通过JDBC来连接客户端的。rdcms主要是数据库的实例名称。在客户端可以通过select instance_name from v$instance来得到实例的名称。

twstcptest.com.User=zabbix      #数据库用户

twstcptest.com.Password=zabbix  #数据库用户密码

twstcptest.com.MaxActive=10

twstcptest.com.MaxWait=100

twstcptest.com.MaxIdle=1

twstcptest.com.QueryListFile=./conf/query.props

配置参考

###】cat config.props

#comma separed list of Zabbix servers

ZabbixServerList=ZabbixServer1

ZabbixServer1.Address=192.168.50.34

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=DB1,DB2,DB3

DatabaseList=Yueqing7

#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

Yueqing7.Url=jdbc:oracle:thin:@192.168.20.2:1521:boncdev

Yueqing7.User=bmonitor

Yueqing7.Password=bmonitor

Yueqing7.QueryListFile=./conf/query.props

四、客户端操作: 登录数据库并授予用户相关权限即可

1.新建用户:

-Create a User for Orabbix to access your Oracle Database. You can use the following script:

SQL> CREATE TABLESPACE TBS_bmonitor DATAFILE '/oradata01/boncdev/oradata/BONCDEV/datafile/tbs_bmonitor_1g_01.dbf' SIZE 1024M AUTOEXTEND OFF;

SQL> CREATE USER bmonitor IDENTIFIED BY bmonitor DEFAULT TABLESPACE tbs_bmonitor TEMPORARY TABLESPACE TEMP PROFILE DEFAULT ACCOUNT UNLOCK;

2.基本权限授权

-Roles for bmonitor

SQL> GRANT CONNECT TO bmonitor;

SQL> GRANT RESOURCE TO bmonitor;

SQL> ALTER USER bmonitor DEFAULT ROLE ALL;

3.粗粒度授权

-5 System Privileges for BMONITOR

SQL> GRANT SELECT ANY TABLE TO BMONITOR;

SQL> GRANT CREATE SESSION TO BMONITOR;

SQL> GRANT SELECT ANY DICTIONARY TO BMONITOR;

SQL> GRANT UNLIMITED TABLESPACE TO BMONITOR;

SQL> GRANT SELECT ANY DICTIONARY TO BMONITOR;

4.细粒度授权

SQL> GRANT SELECT ON V_$INSTANCE TO bmonitor;

SQL> GRANT SELECT ON DBA_USERS TO bmonitor;

SQL> GRANT SELECT ON V_$LOG_HISTORY TO bmonitor;

SQL> GRANT SELECT ON V_$PARAMETER TO bmonitor;

SQL> GRANT SELECT ON SYS.DBA_AUDIT_SESSION TO bmonitor;

SQL> GRANT SELECT ON V_$LOCK TO bmonitor;

SQL> GRANT SELECT ON DBA_REGISTRY TO bmonitor;

SQL> GRANT SELECT ON V_$LIBRARYCACHE TO bmonitor;

SQL> GRANT SELECT ON V_$SYSSTAT TO bmonitor;

SQL> GRANT SELECT ON V_$PARAMETER TO bmonitor;

SQL> GRANT SELECT ON V_$LATCH TO bmonitor;

SQL> GRANT SELECT ON V_$PGASTAT TO bmonitor;

SQL> GRANT SELECT ON V_$SGASTAT TO bmonitor;

SQL> GRANT SELECT ON V_$LIBRARYCACHE TO bmonitor;

SQL> GRANT SELECT ON V_$PROCESS TO bmonitor;

SQL> GRANT SELECT ON DBA_DATA_FILES TO bmonitor;

SQL> GRANT SELECT ON DBA_TEMP_FILES TO bmonitor;

SQL> GRANT SELECT ON DBA_FREE_SPACE TO bmonitor;

SQL> GRANT SELECT ON V_$SYSTEM_EVENT TO bmonitor;

SQL> GRANT SELECT ON v_$log TO bmonitor;

SQL> GRANT SELECT ON v_$locked_object TO bmonitor;

SQL> GRANT SELECT ON v_$session TO bmonitor;

SQL> GRANT SELECT ON dba_tablespaces TO bmonitor;

SQL> GRANT SELECT ON dba_objects TO bmonitor;

SQL> GRANT SELECT ON v_$archived_log to bmonitor;

SQL> GRANT SELECT ON V_$SGA to bmonitor;

5.

如果是oracle11g的数据库版本或者以上,还需要执行下面的语句开放ACL的访问控制,否则在监控的过程中有部份内容无法正常显示(例于数据库版本,数据库文件大小等),而且orabbix的日志显示中也会有错误提示。:

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;

五、模板导入 (监控模板文件 Orabbix_export_full.xml 在orabbix.zip压缩包 template 目录内)

1)创建 Host groups

2)导入模版xml文件  Configuration >Templates > Import file (选择orabbix自带模板导入)>  Import

3) 创建 HOSTS,并关联oracle监控模板

创建 hosts (注意 Host name 要与  /opt/orabbix/conf/config.props 文件配置一致。

关联oracle监控模板 :Host -> Templates -> Link new templates -> Select

六、 监控效果

问题1:
ORA-28040: No matching authentication protocol错误,低客户端连接到12c高版本的解决方案
解决:在Oracle用户(不是grid用户)下,将$ORACLE_HOME/network/admin/sqlnet.ora文件原来的SQLNET.ALLOWED_LOGON_VERSION=8注释掉(如果没有sqlnet.ora文件,那么就创建一个),修改为如下的行:

SQLNET.ALLOWED_LOGON_VERSION_SERVER=8
SQLNET.ALLOWED_LOGON_VERSION_CLIENT=8

不用重启数据库或者监听,也不用重启应用。

问题2:

Import failed

Details

·        Host group "Templates"already exists.

解决方法:将orabbix的4个xml里面的<group>TEMPLATES</group>改成
<group>TEMPLATES_ORACLE</group>,然后重新导入import即可。

问题3:
cannot send list of active checks to "192.168.1.99": host [192.168.1.99] not found

web前端 hosts name 跟 配置文件内不一致

zabbix之 orabbix模板监控oracle的更多相关文章

  1. Zabbix利用orabbix插件监控Oracle数据库

    一.jdk的安装(Orabbix Server) 1.软件解压,放到固定位置 1 2 tar zxf jdk-8u51-linux-x64.tar.gz mv jdk1.8.0_51/ /usr/lo ...

  2. 通过zabbix自带模板监控windowsPC机器

       通过zabbix自带模板监控windowsPC机器   作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.       欢迎加入:高级运维工程师之路 598432640 相信有很多 ...

  3. zabbix自定义模板监控oracle

    zabbix服务器端安装:zabbix-3.2.6.tar.gzzabbix client端安装:zabbix-agent-3.2.6-1.x86_64.rpm 1.首先必须在目标机器安装zabbix ...

  4. orabbix自定义监控oracle

    前提:安装orabbix 好后能正常运行, 检验条件(1). 最新数据有数据  (2).图形有显示 (3).日志不报错 /opt/orabbix/logs/orabbix.log   添加方法: 1. ...

  5. Zabbix自带模板监控MySQL

    先使用主机链接Mysql模板 . 然后写获取mysql状态的脚本,即配合zabbix模板里面的参数的脚本. #!/bin/bash MYSQL_USER='zabbix' #这里为在本地数据库授权的账 ...

  6. orabbix插件监控oracle表空间问题

    我们安装好orabbix插件后,查看Tablespaces监控项是发项值为none,第一反应是没监控成功,其实不然. 1.我们打开orabbix监控项参数的路径,下面为Tablespaces的sql代 ...

  7. zabbix使用mysql模板监控mysql

    出现监控项访问拒绝的信息 解决方法是: 在 mysql的 my.cnf 配置中增加 [mysql] user=zabbix password=zabbix [mysqladmin] user=zabb ...

  8. 使用Zabbix监控Oracle数据库

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

  9. Zabbix-agent使用自带模板监控 MySQL

    1.rpm -ivh http://repo.zabbix.com/zabbix/2.4/rhel/6/x86_64/zabbix-release-2.4-1.el6.noarch.rpm 2.yum ...

随机推荐

  1. Vue源码之 Vue的生命周期

    天地初开就是new Vue(options),里面就一句话 this._init(options); (Vue.prototype.init 的赋值在initMixin(Vue)方法里) _init方 ...

  2. JS-斜杠和反斜杠的转换

    例子:var url = "http://localhost:64177/Home/AccordionIndex"; 将斜杠转换成反斜杠: url = url .replace(& ...

  3. yum安装的Nginx添加第三方模块支持tcp

    需求:生产有个接口是通过socket通信.nginx1.9开始支持tcp层的转发,通过stream实现的,而socket也是基于tcp通信. 实现方法:Centos7.2下yum直接安装的nginx, ...

  4. C#ATM

    using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threa ...

  5. 解决 c3p0报错 Establishing SSL connection without server's identity verification is not recommended

    _ 报错: Establishing SSL connection without server's identity verification is not recommended. Accordi ...

  6. sqlserver查看锁表进程及对锁定的表进行解锁

    select request_session_id spid,object_name(resource_associated_entity_id) tableName from sys.dm_tran ...

  7. 查看python中模块的所有方法

    查看python中模块的所有方法     安装的python模块,现将查看方法总结如下 一.CMD命令行下使用pydoc命令 在命令行下运行$ pydoc modules即可查看 二.在python交 ...

  8. Netty 中 EventLoopGroup 的创建

    本文是基于 Netty 4.1.6.Final 的源码来分析的. 在分析源码之前做一些准备工作: 先熟悉一下 IDEA 的几个快捷键,能极大的提高我们查看源码的效率: Ctrl + Alt + B:用 ...

  9. BZOJ-3105: 新Nim游戏 (nim博弈&线性基)

    pro: 传统的Nim游戏是这样的:有一些火柴堆,每堆都有若干根火柴(不同堆的火柴数量可以不同).两个游戏者轮流操作,每次可以选一个火柴堆拿走若干根火柴.可以只拿一根,也可以拿走整堆火柴,但不能同时从 ...

  10. apply,call以及bind的区别

    每个函数都包含两个非继承而来的方法:apply()和 call(). 这两个方法的用途都是在特定的作用域中调用函数,实际上等于设置函数体内 this 对象的值. 一.apply() apply()方法 ...