设为首页 收藏本站
查看: 810|回复: 0

[经验分享] check_oracle_health监控oracle

[复制链接]
发表于 2018-9-7 08:50:20 | 显示全部楼层 |阅读模式
一、准备工作
  1.在数据库上创建用户并赋予权限(DBA配合操作;用户、密码待定;只是监控本机数据库TNS、SID)

  CREATE USER nagios>  GRANT CREATE SESSIONTO nagios;
  GRANT SELECT anydictionary TO nagios;
  GRANT SELECT ONV_$SYSSTAT TO nagios;
  GRANT SELECT ONV_$INSTANCE TO nagios;
  GRANT SELECT ON V_$LOGTO nagios;
  GRANT SELECT ONSYS.DBA_DATA_FILES TO nagios;
  GRANT SELECT ONSYS.DBA_FREE_SPACE TO nagios;
  GRANT SELECT ONsys.dba_tablespaces TO nagios;
  GRANT SELECT ONdba_temp_files TO nagios;
  GRANT SELECT ONsys.v_$Temp_extent_pool TO nagios;
  GRANT SELECT ONsys.v_$TEMP_SPACE_HEADER  TO nagios;
  GRANT SELECT ONsys.v_$session TO nagios;
  2.将nagios加入oinstall组
  usermod -a -G oinstall nagios
  二、查看被监控是否安装了perl?并且被监控机安装DBI和DBD
  1.[root@D-MDB-90 ~]# perl -v
  This is perl, v5.10.1 (*) built forx86_64-linux-thread-multi
  Copyright 1987-2009, Larry Wall
  Perl may be copied only under theterms of either the Artistic License or the
  GNU General Public License, which maybe found in the Perl 5 source kit.
  Complete documentation for Perl,including FAQ lists, should be found on
  this system using "manperl" or "perldoc perl". If you have access to the
  Internet, point your browser athttp://www.perl.org/, the Perl Home Page.
  2.下载DBI
  wget http://www.cpan.org/authors/id/T/TI/TIMB/DBI-1.636.tar.gz
  3.解压DBI
  [root@D-MDB-90 src]#tar zxvf DBI-1.636.tar.gz
  4.安装DBI
  [root@D-MDB-90 src]# cd DBI-1.636
  [root@D-MDB-90 DBI-1.636]# perlMakefile.PL
  [root@D-MDB-90 DBI-1.636]# make all
  [root@D-MDB-90 DBI-1.636]# make install
  5.下载安装DBD-Oracle
  [root@D-MDB-90 src]# wget http://mirrors.neusoft.edu.cn/cpan/authors/id/P/PY/PYTHIAN/DBD-Oracle-1.74.tar.gz
  [root@D-MDB-90 src]# tar zxvf DBD-Oracle-1.74.tar.gz
  [root@D-MDB-90 src]# cd DBD-Oracle-1.74
  [root@D-MDB-90DBD-Oracle-1.74]# perl Makefile.PL
  6.这里会碰到安装错误
  切换到oracle用户:su - oracle
  查看ORACLE_HOME路径:echo $ORACLE_HOME
  [root@D-MDB-90libexec]# echo $ORACLE_HOME /oracle/app/oracle/products/11.2.0.3/db   #记住这条oracle_home环境
  7.重新切回root:ctrl+d或su - root设置环境变量[root@D-MDB-90DBD-Oracle-1.74]#export ORACLE_HOME=/oracle/app/oracle/products/11.2.0.3/db
  [root@D-MDB-90 DBD-Oracle-1.74]# perl Makefile.PL
  [root@D-MDB-90DBD-Oracle-1.74]#make && make install
  三、下载安装check_oracle_health
  1.[root@D-MDB-90 src]# wget https://labs.consol.de/assets/downloads/nagios/check_oracle_health-2.1.3.5.tar.gz
  2.[root@D-MDB-90 src]# tar -zxvfcheck_oracle_health-2.1.3.5.tar.gz
  3.[root@D-MDB-90 src]#cd check_oracle_health-2.1.3.5
  4. ./configure --prefix=/usr/local/nagios--with-nagios-user=nagios --with-nagios-group=nagios--with-mymodules-dir=/usr/local/nagios/libexec --with-mymodules-dyndir=/usr/local/nagios/libexec
  5. [root@D-MDB-90 src]make all
  6.[root@D-MDB-90 src]make install
  7.chown nagios:nagios/usr/local/nagios/libexec/check_oracle_health
  8.chmod 775/usr/local/nagios/libexec/check_oracle_health
  四、测试
  1.安装完成后执行命令:/usr/local/nagios/libexec/check_oracle_health --connect=oracle_SID    --user=oracle用户 --password=oracle用户密码 --mode=connected-users
  如果提示错误:如
DSC0000.png

  解决方法:
  [root@D-MDB-90libexec]# ldd /usr/local/lib64/perl5/auto/DBD/Oracle/Oracle.so (安装缺少文件路径找)
  发现没有libclntsh.so.11.1
  [root@D-MDB-90libexec]# locate  libclntsh.so.11.1
DSC0001.png

  [root@D-MDB-90 libexec]# ln -s /oracle/app/oracle/products/11.2.0.3/db/lib/libclntsh.so.11.1(空格)/lib/libclntsh.so.11.1
  [root@D-MDB-90 libexec]# vim /etc/ld.so.conf
  添加
  include ld.so.conf.d/*.conf
  /oracle/app/oracle/products/11.2.0.3/db/lib  #这里的路径与libclntsh.so.11.1 的路径有关
  [root@D-MDB-90 libexec]# ldconfig
DSC0002.png

  [root@D-MDB-90 libexec]# ldd/usr/local/lib64/perl5/auto/DBD/Oracle/Oracle.so
DSC0003.png

  2.[root@D-MDB-90 libexec]#/usr/local/nagios/libexec/check_oracle_health --connect=pomoho --user=nagios --password=oradbmon --mode=tnsping
  结果输出OK - connection established to pomoho.
  3.修改/usr/local/nagios/etc/nrpe.cfg
  在allowed_hosts后加上本机与监控主机的IP
  最后加一行command[check_oracle_health]=/usr/local/nagios/libexec/check_oracle_health --connect=oracle_SID    --user=oracle用户 --password=oracle用户密码 --mode=tnsping
  4.重启nrpe
  5./usr/local/nagios/libexec/check_nrpe -H你的被监控机IP地址 -c check_oracle_health
  如果结果同样为OK - connectionestablished to pomoho,则OK
  五、修改监控主机的/usr/local/nagios/etc/objects/services.cfg
  添加
  ###################XX-XXX-XXcheck_oracle_health#####################################
  define service{
  host_name               XX-XXX-XX
  service_description    check_oracle_health_tnsping
  check_command          check_nrpe!check_oracle_health
  max_check_attempts      5
  normal_check_interval   5
  retry_check_interval    2
  check_period            24x7
  notification_interval   10
  notification_period     24x7
  notification_options    w,u,c,r
  contact_groups          yunwei
  }
  检查配置是否正确 /usr/local/nagios/bin/nagios -v /usr/local/nagios/etc/nagios.cfg

  重新加载nagios : service nagios>

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-565473-1-1.html 上篇帖子: Oracle varchar2或char类型的byte和char的区别 下篇帖子: ORACLE 10GR2 DATAGUARD ON RHEL 6-Open World-51CTO博客
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表