nagios监控oracle 表空间
oracle表空间满的危害以及处理方式见我的博客链接https://www.cnblogs.com/-abm/p/9764803.html
除此之外我们还需要对表空间实时监控,这样就可以及时了解表空间的使用状况,防患于未然。
监控工具
nagios(nagios的工作原理需要清晰,这里不做介绍)
nagios自带了oracle监控相关脚本,查看它的帮助的命令如下:
# /usr/local/nagios/libexec/check_oracle -h
Usage:
check_oracle --tns <Oracle Sid or Hostname/IP address>
check_oracle --db <ORACLE_SID>
check_oracle --login <ORACLE_SID>
check_oracle --connect <ORACLE_SID>
check_oracle --cache <ORACLE_SID> <USER> <PASS> <CRITICAL> <WARNING>
check_oracle --tablespace <ORACLE_SID> <USER> <PASS> <TABLESPACE> <CRITICAL> <WARNING>
check_oracle --oranames <Hostname>
check_oracle --help
check_oracle --version
开始配置监控
2.1、按照命令帮助中的提示,测试nagios 监控oracle表空间
格式:check_oracle --tablespace <ORACLE_SID> <USER> <PASS> <TABLESPACE> <CRITICAL> <WARNING>
最好先在命令行下实验脚本的正确性,以及结果的准确度
举例有问题的情况:
# /usr/local/nagios/libexec/check_oracle --tablespace orcl sys mima users
CRITICAL - ORA-28009: ??? SYSDBA ??? SYSOPER ???? SYS ??
//报错提示:用sys用户登录必须要加as sysdba,所以我自己查看了nagios的监控脚本并修改了部分内容(修改内容见最后),然后正常执行了。
正常执行
# /usr/local/nagios/libexec/check_oracle --tablespace pdb_xxx sys mima USERS 90 80;
pdb_shwjs : USERS CRITICAL - 95.30% used [ 12613 / 268144 MB available ]|USERS=95.30%;80;90;0;100
2.2、加入到监控配置文件中
# vim /usr/local/nagios/etc/nrpe.cfg,加入监控内容条目
......
#check oracle_tablespace
command[check_oracle_tab]=/usr/local/nagios/libexec/check_oracle --tablespace pdb_shwjs sys SHipii314 USERS 97
//这里的check_oracle_tab是用于服务端调用的标识符
配置完成重启客户端nrpe,使监控项目生效
# service xinetd restart
Stopping xinetd: [ OK ]
Starting xinetd: [ OK ]
2.3、配置服务端
服务端先用命令行测试
# ../libexec/check_nrpe -H 192.168.13.103 -c check_oracle_tab
pdb_shwjs : USERS OK - 95.30% used [ / MB available ]|USERS=95.30%;;;;
测试没有问题,写到监控主机的服务配置文件中
# vim services/192.168.13.103.cfg
# 监控oracle_tablespace
define service{
service_description check_oracle_tab ; 定义服务名称(WEB管理台显示的服务标识)
host_name 192.168.13.103 ; 关联的主机名称(引用主机.cfg配置)
check_command check_nrpe!check_oracle_tab ; 执行的监控命令(引用被控端nrpe.cfg配置)
check_period 7x24h ; 监控服务的时间段(引用timeperiods.cfg配置)
normal_check_interval ; 监控检查服务时间间隔(单位/分钟)
retry_check_interval ; 非OK状态重新检查时间间隔(单位/分钟)
max_check_attempts ; 非OK状态重新检查最大次数(达到阀值将触发通知功能)
notifications_enabled ; 是否启用通知功能(1是/0否)
contact_groups gnnt-admins ; 通知发送对象(引用contacts.cfg配置)
notification_options w,u,c,r ; 通知类型(warning、unknown、critical、recovery)
notification_interval ; 重发通知的时间间隔(单位/分钟)
notification_period 7x24h ; 允许发送通知的时间段(引用timeperiods.cfg配置)
active_checks_enabled ; 是否启用主动式服务检查(1是/0否)
passive_checks_enabled ; 是否启用被动式服务检查(1是/0否)
parallelize_check ; 是否启用并行主动服务检查(禁用可能会带来重大性能问题)
obsess_over_service ; 是否保持监控该服务(1是/0否)
event_handler_enabled ; 是否启用事件处理程序(1是/0否)
process_perf_data ; 是否启用过程性能数据功能(1是/0否)
flap_detection_enabled ; 是否否启用Flap检测功能(1是/0否)
retain_status_information ; 是否保留整个程序重新启动的状态信息(1是/0否)
retain_nonstatus_information ; 是否保留整个程序重新启动非状态信息(1是/0否)
}
重新加载nagios
# service nagios reload
Running configuration check...
Reloading nagios configuration...
done
监控效果

附:
nagios监控oracle的脚本修改
--tablespace)
if [ ${} -lt ${} ] ; then
echo "UNKNOWN - Warning level is more then Crit"
exit $STATE_UNKNOWN
fi
result=`sqlplus -s ${}/${}@192.168.13.105:/${} as sysdba << EOF
nagios监控oracle 表空间的更多相关文章
- 使用zabbix监控oracle表空间
0.概述 zabbix是一款极其强大的开源监控工具,下面我分享下zabbix如何监控表空间,跟着这个思路,监控其他项都是类似操作. 前提条件是你已经有了zabbix server和zabbix age ...
- orabbix插件监控oracle表空间问题
我们安装好orabbix插件后,查看Tablespaces监控项是发项值为none,第一反应是没监控成功,其实不然. 1.我们打开orabbix监控项参数的路径,下面为Tablespaces的sql代 ...
- Python巡检Oracle表空间并邮件告警
最近,自学了Python基础,突发奇想,把以前通过shell自定义通过nagios实现Oracle表空间以及ASM以及备份的脚本改进下,首先感叹的是Python脚本看上去确实挺好的,效率还不错. 这是 ...
- Oracle表空间,用户,用户授权
一:Oracle表空间 1,Oracle表空间与SQL Server文件组对比 SQL Server的文件组(文件组包括若干MDF,NDF数据文件)对我们来说并不陌生,前段时间我在博客“怎样玩转千万级 ...
- Oracle表空间管理
oracle表空间相关常用命令小结: 1.ALTER DATABASE SET DEFAULT BIGFILE TABLESPACE; //修改表空间数据文件类型 2.ALT ...
- 【转】Oracle 表空间与数据文件
--============================== --Oracle 表空间与数据文件 --============================== /* 一.概念 表空间:是一个或 ...
- 六分钟学会创建Oracle表空间的步骤
经过长时间学习创建Oracle表空间,于是和大家分享一下,看完本文你肯定有不少收获,希望本文能教会你更多东西. 1.先查询空闲空间 select tablespace_name,file_id,blo ...
- 修改Oracle 表空间名称 tablespace name
修改表空间名称步骤如下: 1. 使用oracle用户登录执行 $sqlplus / as sysdba 2. 执行修改表空间命令如下 SQL> alter tablespace TEST re ...
- interview:about Oracle表空间
Oracle表空间 SQL Server数据库与Oracle数据库之间最大的区别要属表空间设计.Oracle数据库开创性地提出了表空间的设计理念,这为Oracle数据库的高性能做出了不可磨灭的贡献.可 ...
随机推荐
- Go http server 高并发
先来个段子:[并发处理连接数] 多高? 很高! 到底多高? 没有一亿,都算少了! . . . 然后就没有然后了... “段子 END” 这就是目前中国企业的通病:提个概念,没有答案,最后造成概念也模糊 ...
- 第一章 CSS基础
1.CSS:层叠样式表 (1)好处:结构样式分离.样式复用.精确控制布局定位.方便搜索引擎搜索(2)用途:美化修饰.布局定位 2.CSS样式表使用方式(3种):(1)内嵌样式[行内样式]:确定到具体元 ...
- ip and port check 正则
在网页开发中可能会遇到需要对在页面输入的ip和端口进行正确性验证,那么正则表达式就是最有力的工具: 1:ip的正则表达式: 格式是由“.”分割的四部分,每部分的范围是0-255: 每段的正则可以分几部 ...
- Git-分支的建立与合并
举一个实际工作中可能会遇到的分支建立与合并的例子: 开发某个网站. 为实现某个新的需求,创建一个分支. 在这个分支上开展工作. 假设此时,你突然接到一个电话说有个很严重的问题需要紧急修补,那么可以按照 ...
- PKCS#1
ASN.1 syntax,octet string是一个8 bytes sequence string. RSA中涉及到的Data conversion: 1)I2OSP,Integer to Oct ...
- 大话设计模式C++ 备忘录模式
备忘录(Memento):在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态.这样以后就可将对象恢复到原先保存的状态. 角色: (1)Originator(发起人):创建盒子, ...
- linux 下nginx
所有的配置文件都在/etc/nginx (ect/nginx/nginx.conf) 下,并且每个虚拟主机已经安排在 了/etc/nginx/sites-avail ...
- uva 10163 Storage Keepers
题意: 有n个仓库,m个人,一个仓库只能由一个人托管,每个人可以托管多个仓库. 每个人有一个能力值a,如果说他托管了k个仓库,那么这些仓库的安全值都是a/k. 雇佣一个人的花费也是a. 如果一个仓库没 ...
- Swift 了解(3)
类(Classes) 假设你是一个建筑师,你刚刚签了一个合同,要在一个新的小区修建20个相似的房子.在你派出建筑工队之前,你必须要画一个房子的设计图.这份设计图将会展现房子的外表和功能.把这份设计图当 ...
- 【2017-03-13】Tsql 数学函数、字符串函数、转换函数、时间日期函数
一.数学函数(针对值类型操作) 1.ceiling():取上限 只要小数点后有数字大于0,整数位自动进1 2.floor():取下限 将小数点位舍去,不管小数点位大小 3.round(四舍五入的值,保 ...