青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

tbwshc

tbw

  C++博客 :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
  95 Posts :: 8 Stories :: 3 Comments :: 0 Trackbacks

常用鏈接

留言簿(4)

我參與的團(tuán)隊

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

背景:先前在生產(chǎn)庫上配置了oracle監(jiān)控,每5分鐘嘗試連接一次數(shù)據(jù)庫,若連接失敗則通過nagios+fetion自動報警,此配置參考文章:http://ylw6006.blog.51cto.com/470441/787496

早晨收到報警信息后,登陸數(shù)據(jù)庫執(zhí)行ps -ef查看oracle的后臺進(jìn)程都在,使用conn /as sysdba的方式登陸數(shù)據(jù)庫,提示連接到空閑的實(shí)例,使用easy connect 方式連接則報oracle實(shí)例無法分配內(nèi)存,從報錯提示上看,就像oracle數(shù)據(jù)庫實(shí)例未打開的狀態(tài)!分析alert日志不斷出現(xiàn)如下錯誤信息:
Process J002 died, see its trace file
kkjcre1p: unable to spawn jobq slave process
Errors in file /u01/app/oracle/diag/rdbms/orcl/orcl/trace/orcl_cjq0_18577.trc:

trace文件摘要信息如下:
*** 2012-07-26 10:20:31.068
Process J002 is dead (pid=13857 req_ver=1136 cur_ver=1136 state=KSOSP_SPAWNED).

*** 2012-07-26 10:20:32.069
Process J002 is dead (pid=13876 req_ver=1594 cur_ver=1594 state=KSOSP_SPAWNED).

google查詢一番后,發(fā)現(xiàn)大部分描述和oracle的進(jìn)程數(shù)設(shè)置有關(guān),又或者是內(nèi)存不足引起!于是在oracle 10g環(huán)境下測試,線上數(shù)據(jù)庫環(huán)境為11.2.0.3

一:設(shè)置processes初始化參數(shù)值為20,重啟數(shù)據(jù)庫后,已經(jīng)占用19個進(jìn)程

  1. SQL> select count(*) from v$process;  
  2.  
  3.   COUNT(*)  
  4. ----------  
  5.         19  
  6.  
  7. SQL> show parameter process;  
  8.  
  9. NAME                                 TYPE        VALUE  
  10. ------------------------------------ ----------- ------------------------------  
  11. aq_tm_processes                      integer     0  
  12. db_writer_processes                  integer     1  
  13. gcs_server_processes                 integer     0  
  14. job_queue_processes                  integer     10  
  15. log_archive_max_processes            integer     2  
  16. processes                            integer     20 

新的會話連接,則報連接到空閑的實(shí)例,alert日志則出現(xiàn)相應(yīng)的報錯

  1. [root@db1 ~]# su - oracle  
  2. [oracle@db1 ~]$ sqlplus /nolog  
  3. SQL*Plus: Release 10.2.0.1.0 - Production on Wed Jul 4 13:50:22 2012  
  4. Copyright (c) 1982, 2005, Oracle.  All rights reserved.  
  5.  
  6. SQL> conn /as sysdba  
  7. Connected to an idle instance.  
  8.  
  9. [oracle@db1 dbs]$ tail -f /u01/app/oracle/admin/db1/bdump/alert_db1.log   
  10. Wed Jul  4 13:52:23 2012  
  11. ksvcreate: Process(q000) creation failed  
  12. Wed Jul  4 13:52:35 2012  
  13. Process q001 died, see its trace file  
  14. Wed Jul  4 13:52:35 2012  
  15. ksvcreate: Process(q001) creation failed  
  16. Wed Jul  4 13:52:37 2012  
  17. Process m000 died, see its trace file  
  18. Wed Jul  4 13:52:37 2012  
  19. ksvcreate: Process(m000) creation failed 

二:于是想到監(jiān)控oracle的進(jìn)程和會話數(shù)來進(jìn)一步確定問題
1:首先要對用戶進(jìn)行顯示授權(quán),否則后面創(chuàng)建存儲過程編譯將會報錯

  1. SQL> grant select on V_$SESSION tbo hr;  
  2. Grant succeeded.  
  3.  
  4. SQL> grant select on V_$PROCESS to hr;  
  5. Grant succeeded. 

2:建表,用來存儲結(jié)果

  1. SQL> create table session_monitor(time timestamp,session_count number,process_count number);  
  2. Table created. 

3:創(chuàng)建存儲過程,將數(shù)據(jù)插入表

  1. SQL> create or replace procedure proc_session  
  2.   2  is  
  3.   3  v_session number(8);  
  4.   4  v_process number(8);  
  5.   5  begin  
  6.   6   select count(*) into v_session from v$session;  
  7.   7   select count(*) into v_process from v$process;  
  8.   8   insert into session_monitor values (sysdate,v_session,v_process);  
  9.   9   commit;  
  10.  10  end proc_session;  
  11. Procedure created. 

4:創(chuàng)建任務(wù)

  1. SQL> var job number;  
  2. SQL> begin  
  3.   2    sys.dbms_job.submit(job => :job,  
  4.   3                        what => 'proc_session();',  
  5.   4                        next_date => sysdate,  
  6.   5                        interval => 'sysdate+2/1440');  
  7.   6* end;  
  8. PL/SQL procedure successfully completed. 

5:測試效果

  1. SQL> exec proc_session;  
  2. PL/SQL procedure successfully completed.  
  3.  
  4. SQL> alter session set nls_date_format='YYYY-MM-DD-HH24:MI:SS';  
  5. Session altered.  
  6.  
  7. SQL>  select * from session_monitor;  
  8.  
  9. TIME                                     SESSION_COUNT PROCESS_COUNT  
  10. ---------------------------------------- ------------- -------------  
  11. 26-JUL-12 03.02.12.000000 PM                       140           155  
  12. 26-JUL-12 03.02.14.000000 PM                       141           157  
  13.  
  14. SQL> select job,next_date from user_jobs where what='proc_session();';  
  15.  
  16.        JOB NEXT_DATE  
  17. ---------- -------------------  
  18.        145 2012-07-26-15:04:14  
  19.  
  20. SQL> select * from session_monitor;  
  21.  
  22. TIME                                     SESSION_COUNT PROCESS_COUNT  
  23. ---------------------------------------- ------------- -------------  
  24. 26-JUL-12 03.04.14.000000 PM                        87            94  
  25. 26-JUL-12 03.02.12.000000 PM                       140           155  
  26. 26-JUL-12 03.02.14.000000 PM                       141           157 

6:如果要刪除任務(wù),則運(yùn)行下列的命令,145代表user_jobs視圖中的job列

  1. SQL> begin  
  2.   2  dbms_job.remove(145);  
  3.   3  end;  
  4. PL/SQL procedure successfully completed. 

三:使用nagios+fetion,定時去監(jiān)控會話和進(jìn)程數(shù)
1:創(chuàng)建監(jiān)控腳本,該腳本放任務(wù)計劃中運(yùn)行,每2分鐘自動執(zhí)行

  1. [root@server240 libexec]# cat session_oracle.sh   
  2. #!/bin/sh  
  3. rm -rf /tmp/session_oracle.log  
  4. export ORACLE_HOME=/u01/app/oracle/product/11.2.0/db1  
  5. /u01/app/oracle/product/11.2.0/db1/bin/sqlplus hr/hr@192.168.1.240:1521/orcl <<EOF 
  6. set echo off  
  7. set feedback off  
  8. spool /tmp/session_oracle.log  
  9. alter session set nls_date_format='YYYY-MM-DD:HH24:MI:SS';  
  10. select session_count from (select * from session_monitor order by time desc ) where  rownum=1;  
  11. select process_count from (select * from session_monitor order by time desc ) where  rownum=1;  
  12. spool off  
  13. set echo on  
  14. set feedback on  EOF

2:創(chuàng)建第二腳本,用來處理前面監(jiān)控腳本的日志輸出,將結(jié)果返回給監(jiān)控服務(wù)器

  1. [root@server240 ~]# cat /tmp/session_oracle.log
    SQL> alter session set nls_date_format='YYYY-MM-DD:HH24:MI:SS';
    SQL> select session_count from (select * from session_monitor order by time desc ) where  rownum=1;
  2. SESSION_COUNT                                                                  
    -------------                                                                  
              138                                                                  
    SQL> select process_count from (select * from session_monitor order by time desc ) where  rownum=1;
  3. PROCESS_COUNT                                                                  
    -------------                                                                  
              153                                                                  
    SQL> spool off
  4.  
  5. [root@server240 libexec]# cat check_oracle_session.sh   
  6. #!/bin/sh  
  7. STATE_OK=0 
  8. STATE_CRITICAL=2 
  9.  
  10. if  [ -f /tmp/session_oracle.log  ];then  
  11.      SESSION=$(grep -A 2 'SESSION_COUNT'  /tmp/session_oracle.log |tail -1|sed 's/[ ][ ]*//g')  
  12.      PROCESS=$(grep -A 2 'PROCESS_COUNT'  /tmp/session_oracle.log |tail -1|sed 's/[ ][ ]*//g')  
  13.      else   
  14.      echo "something wrong,please check monitor script"  
  15.      exit $STATE_CRITICAL  
  16. fi  
  17.  
  18. if   [ $SESSION -gt 500 ] || [ $PROCESS -gt 500 ];then   
  19.      echo "Current session is $SESSION,process is $PROCESS "  
  20.      exit $STATE_CRITICAL  
  21.      else   
  22.        echo "Current session is $SESSION,process is $PROCESS "  
  23.        exit $STATE_OK  
  24. fi 

四:實(shí)際效果
[root@server198 ~]# /usr/local/nagios/libexec/check_nrpe -H 192.168.1.240 -c check_oracle_session
Current session is 138,process is 153

五:后期觀察結(jié)果,估計和內(nèi)存問題相關(guān)
[oracle@server240 ~]$ sar -r |grep 10:20
10:20:02 AM   3481492  21195164     85.89    675584  13661448   3683012    413552     10.10     
[oracle@server240 ~]$ sar -r |grep 04:40
04:40:01 PM   2076748  22599908     91.58    734088  14581728   4048864     47700      1.16

posted on 2012-07-28 12:43 tbwshc 閱讀(1067) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲欧美日韩一区二区在线| 欧美吻胸吃奶大尺度电影| 国产精品视频导航| 亚洲深夜激情| 日韩视频一区二区在线观看 | 一区二区三区国产精华| 亚洲黄网站黄| 欧美激情第10页| 一本大道久久a久久精品综合| 亚洲国产成人午夜在线一区| 亚洲日本免费| 国产欧美一区二区三区视频| 亚洲伊人观看| 一区二区三区视频免费在线观看 | 9色国产精品| 欧美日韩国产在线| 中文欧美字幕免费| 午夜一级在线看亚洲| 国产乱子伦一区二区三区国色天香| 亚洲欧美精品| 久久精品夜色噜噜亚洲a∨| 尤物精品在线| 亚洲日韩欧美视频一区| 欧美日韩一区自拍| 欧美一区视频| 欧美91视频| 99精品免费| 欧美激情一区二区在线| 国产精品久久久久久久久久免费看 | 国产一区二区在线观看免费播放| 欧美一级大片在线观看| 久久久99精品免费观看不卡| 亚洲精品久久视频| 亚洲一区一卡| 亚洲激情在线激情| 中文精品视频| 在线看欧美视频| 99国产精品视频免费观看一公开| 国产精品一区免费在线观看| 在线观看视频一区二区欧美日韩 | 嫩草国产精品入口| 欧美裸体一区二区三区| 久久久精品999| 欧美日韩视频专区在线播放| 久久蜜桃精品| 欧美午夜在线一二页| 欧美不卡在线| 国产欧美精品国产国产专区| 亚洲黄色一区二区三区| 国产午夜精品在线观看| 99视频在线精品国自产拍免费观看 | 最近中文字幕日韩精品| 黄色精品一区二区| 亚洲一区二区三区在线观看视频 | 国产精品视频不卡| 亚洲精品久久久久久久久久久久久| 国产亚洲成精品久久| 亚洲天堂第二页| 99re亚洲国产精品| 噜噜噜在线观看免费视频日韩| 欧美一区二区三区在线免费观看| 欧美片在线观看| 亚洲国语精品自产拍在线观看| 尤物99国产成人精品视频| 欧美一进一出视频| 久久精品免费播放| 国产精品综合| 亚洲欧美日韩一区二区三区在线观看 | 好吊日精品视频| 亚洲欧美在线一区二区| 性色av一区二区三区在线观看| 欧美视频精品在线| 中文国产成人精品| 亚洲欧美激情一区二区| 国产精品久久97| 亚洲一区激情| 欧美一区二区精品久久911| 国产精品久久久久久影视| 在线一区免费观看| 欧美一区二区福利在线| 国产欧美综合在线| 久久国产黑丝| 女同性一区二区三区人了人一| 在线观看视频一区二区欧美日韩 | 欧美激情亚洲国产| 亚洲毛片视频| 国产精品v片在线观看不卡| 亚洲调教视频在线观看| 欧美在线视频观看| 永久免费视频成人| 欧美极品影院| 亚洲一区二区三区成人在线视频精品| 性欧美videos另类喷潮| 国产综合视频| 免费视频一区| 亚洲香蕉网站| 美女福利精品视频| 99精品国产在热久久下载| 国产精品欧美日韩| 老司机免费视频一区二区三区| 亚洲人午夜精品| 久久国产精品一区二区| 亚洲国产精品专区久久 | 亚洲天堂成人| 你懂的国产精品| 日韩图片一区| 国产欧美日韩精品一区| 欧美99在线视频观看| 亚洲一区二区黄色| 欧美激情一区在线观看| 午夜在线a亚洲v天堂网2018| 亚洲国产裸拍裸体视频在线观看乱了中文 | 国产精品性做久久久久久| 午夜精品国产更新| 亚洲国产另类久久精品| 亚洲欧美日韩在线不卡| 一区二区亚洲精品| 欧美日韩国产在线播放| 久久精品国产在热久久 | 久久精品最新地址| 一本不卡影院| 韩日欧美一区| 国产精品影视天天线| 欧美成人免费在线视频| 欧美专区第一页| 中国成人黄色视屏| 亚洲国产天堂久久综合| 久久人人精品| 欧美亚洲一区三区| 亚洲一级二级在线| 日韩视频―中文字幕| 亚洲成色www8888| 国产一在线精品一区在线观看| 欧美日韩在线高清| 欧美国产免费| 美脚丝袜一区二区三区在线观看 | 欧美成人第一页| 久久久91精品国产| 午夜亚洲视频| 亚洲一区尤物| 亚洲一级高清| 亚洲一区视频| 亚洲永久免费观看| 99视频精品全部免费在线| 亚洲国产岛国毛片在线| 激情丁香综合| 韩国视频理论视频久久| 国产毛片久久| 国产乱码精品| 国产视频一区欧美| 国产午夜精品久久久久久久| 国产精品永久免费在线| 国产精一区二区三区| 国产乱码精品一区二区三| 国产伦精品一区二区三区在线观看| 欧美视频网址| 国产精品青草综合久久久久99| 国产精品久久久久久久久久ktv| 国产精品a久久久久久| 国产精品久久久久秋霞鲁丝| 国产精品日日摸夜夜添夜夜av| 国产精品一区免费观看| 国产亚洲制服色| 影音先锋日韩精品| 亚洲精品国精品久久99热| 99xxxx成人网| 午夜精品剧场| 久久九九热免费视频| 免费在线国产精品| 亚洲国产老妈| 亚洲视频在线观看| 欧美综合国产精品久久丁香| 久久天堂精品| 欧美精品国产精品| 国产乱码精品1区2区3区| 激情六月综合| 一区二区高清视频在线观看| 亚洲欧美自拍偷拍| 老司机精品导航| 亚洲精品久久久久久久久久久久久| 中日韩美女免费视频网址在线观看 | 亚洲香蕉网站| 老牛国产精品一区的观看方式| 免费欧美电影| 亚洲视频在线视频| 久久综合影音| 国产精品www| 在线观看国产精品网站| 中文亚洲免费| 快射av在线播放一区| 一区二区国产在线观看| 久久久国产视频91| 欧美视频免费| 亚洲人www| 久久久高清一区二区三区| 亚洲美女在线视频| 久久婷婷国产综合国色天香| 欧美午夜精品一区二区三区| 亚洲国产高清在线观看视频| 欧美一区二区成人6969|