zabbix之 orabbix模板监控oracle
一、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的更多相关文章
- Zabbix利用orabbix插件监控Oracle数据库
一.jdk的安装(Orabbix Server) 1.软件解压,放到固定位置 1 2 tar zxf jdk-8u51-linux-x64.tar.gz mv jdk1.8.0_51/ /usr/lo ...
- 通过zabbix自带模板监控windowsPC机器
通过zabbix自带模板监控windowsPC机器 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 欢迎加入:高级运维工程师之路 598432640 相信有很多 ...
- zabbix自定义模板监控oracle
zabbix服务器端安装:zabbix-3.2.6.tar.gzzabbix client端安装:zabbix-agent-3.2.6-1.x86_64.rpm 1.首先必须在目标机器安装zabbix ...
- orabbix自定义监控oracle
前提:安装orabbix 好后能正常运行, 检验条件(1). 最新数据有数据 (2).图形有显示 (3).日志不报错 /opt/orabbix/logs/orabbix.log 添加方法: 1. ...
- Zabbix自带模板监控MySQL
先使用主机链接Mysql模板 . 然后写获取mysql状态的脚本,即配合zabbix模板里面的参数的脚本. #!/bin/bash MYSQL_USER='zabbix' #这里为在本地数据库授权的账 ...
- orabbix插件监控oracle表空间问题
我们安装好orabbix插件后,查看Tablespaces监控项是发项值为none,第一反应是没监控成功,其实不然. 1.我们打开orabbix监控项参数的路径,下面为Tablespaces的sql代 ...
- zabbix使用mysql模板监控mysql
出现监控项访问拒绝的信息 解决方法是: 在 mysql的 my.cnf 配置中增加 [mysql] user=zabbix password=zabbix [mysqladmin] user=zabb ...
- 使用Zabbix监控Oracle数据库
Orabbix介绍 监控Oracle数据库我们需要安装第三方提供的Zabbix插件,我们先测试比较有名的Orabbix,http://www.smartmarmot.com/product/orabb ...
- 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 ...
随机推荐
- 服务集群session问题
1. http协议本身无状态,可通过Session与Cookie记录前端与后端服务器的交互状态: 2. 但是每次客户端回传必须在头信息中带有cookie, 如果session过多,会增加数据传输量: ...
- c#线程池ThreadPool实例详解
1. 如何查看线程池的最大线程数和最小线程数 static void Main(string[] args) { Console.WriteLine("----------线程池开始,线程I ...
- this.$nextTick()作用
当data中的某个属性改变的时候,这个值并不是立即渲染到页面上,而是先放到watcher队列上(异步),只有当前任务空闲的时候才会去执行watcher队列上的任务.所以导致,改变的数据挂载到dom上会 ...
- linux之正则
grep命令: -V 打印grep的版本号 -E 解释PATTERN作为扩展正则表达式,也就相当于使用egrep. -F 解释PATTERN作为固定字符串的列表,由换行符 ...
- Sharepoint 2016 配置FBA(四)添加用户到Membership数据库
现在还不能用FBA登录,因为数据库还没有用户. 有一些方法来管理membership数据库,有可以用IIS来管理.推荐使用 SharePoint 2016 FBA Pack(https://share ...
- Java中String类常用方法(字符串中的子字符串的个数)
重点内容 4种方法: 1.int indexOf(String str)返回第一次出现的指定子字符串在此字符串中的索引. 2.int indexOf(String str, int startInde ...
- 小程序之--canvasToTempFilePath
最近做的小程序需要图片上传头像的功能,不对上传的图片做处理肯定出来的效果不好:所以就隐藏了一个canvas对上传的图片进行压缩或者进行大小的编辑: 通过chooseImage方法,可以拿到图片的临时路 ...
- Running cells requires Jupyter notebooks to be installed
/******************************************************************************* * Running cells req ...
- python request 和requests 的区别
说明: 这里主要记录一下requests模块的如下几点: 1.requests模块的安装 2.requests模块发送get请求 3.requests模块发送post请求 4.requests模块上传 ...
- 列表中使用嵌套for循环[i*j for i in range(3) for j in range(3)]
利用嵌套for循环形成一个新列表 [i*j for i in range(3) for j in range(3)]相当于如下代码 li=[] for i in range(3): for j in ...