nagios mysql 监控脚本_巧用Nagios脚本监控Oracle连接

场景:程序修改完成后,上传到应用服务器tomcat,重启tomcat后,发现启动异常!前端nginx负载均衡出现504错误,网站无法打开!排

场景:

程序修改完成后,上传到应用服务器tomcat,重启tomcat后,发现启动异常!前端nginx负载均衡出现504错误,网站无法打开!

排查:

经过排查tomcat日志,发现连接数据库异常;登陆数据库后以"conn /as sysdba"方式登陆正常,数据库轻载,无压力;于是检查数据库的监听器,,输入"lsntctl services"命令,卡住,半天不出结果…

故障处理:

输入"lsntctl stop" 或者"lsntctl reload"命令,卡住,半天不出结果,于是输入service network restart命令,一样没有效果!于是出必杀技,输入"netstat -ntpl|grep :1521"命令找出监听器的进程号,kill -9结束掉,然后重启监听器,再启动tomcat正常,网站访问畅通无阻!

原因分析:

可能由于数据库bug的原因,出现监听器卡住的情况,导致数据库连接失败!参见:

后期维护:

为了尽量避免这种问题,想到去写一个监控脚本配合nagios监控,当数据库连接异常的时候,可以第一时间收到报警短信;java程序连接数据库使用连接池,所以不一定会及时暴露出问题!

写一个脚本放任务计划中运行,定期去连接下数据库,查询下系统时间和数据库的状态,spool输出到临时文件上

[root@server199 ~]# crontab -l

*/5 * * * * /usr/local/nagios/libexec/connect_Oracle.sh

[root@server199 ~]# cat /usr/local/nagios/libexec/connect_oracle.sh

#!/bin/sh

#functions: connect oracle server test

#author:lw.yang

#modify_date: 2012-02-22

rm -rf /tmp/check_oracle.log

export ORACLE_HOME=/u01/app/oracle/product/10.2.0/db_1/

$ORACLE_HOME/bin/sqlplus username/password@ip:1521/services_name

set feedback off

spool /tmp/check_oracle.log

alter session set nls_date_format='YYYY-MM-DD:HH24:MI:SS';

select sysdate from dual;

select name,open_mode from v\$database;

spool off

set echo on

set feedback on

EOF

logo.gif

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值