zoukankan      html  css  js  c++  java
  • 【oracle案例】ORA-01102: cannot mount database in EXCLUSIVE mode

    ORA-01102: cannot mount database in EXCLUSIVE mode

    今天在fedora上安装完10g后,测试数据库是否安装成功。STARTUP数据库时,发生如下错误:
     
     
    1. SQL> conn /as sysdba  
    2. Connected to an idle instance.  
    3. SQL> startup  
    4. ORACLE instance started.  
    5. Total System Global Area  591396864 bytes  
    6. Fixed Size                   1220724 bytes  
    7. Variable Size             167776140 bytes  
    8. Database Buffers         415236096  bytes  
    9. Redo Buffers                 7163904 bytes  
    10. ORA-01102: cannot mount database in EXCLUSIVE mode  
    11. SQL> shutdown immediate  
    12. ORA-01507: database not mounted  
    13.   
    14. ORACLE instance shut down.  



     
    出现ORA-1102错误可能有以下几种可能:
    一、在HA系统中,已经有其他节点启动了实例,将双机共享的资源(如磁盘阵列上的裸设备)占用了;
    二、说明Oracle被异常关闭时,有资源没有被释放,一般有以下几种可能,
    1、 Oracle的共享内存段或信号量没有被释放;
    2、 Oracle的后台进程(如SMON、PMON、DBWn等)没有被关闭;
    3、 用于锁内存的文件lk<sid>和sgadef<sid>.dbf文件没有被删除。
     
    第一点,可以通过在备节点上查数据库状态来判断是否已启动实例。
    第二点,如果系统是因为断电引起数据库宕机的,并且系统在接电被重启后,我们可以排除第二种可能的1、2点。接下来考虑第3点。
    查$ORACLE_HOME/dbs目录:
    1. [oracle@localhost dbs]$ ls sgadef*  
    2. ls: cannot access sgadef*: No such file or directory  
    3. [oracle@localhost dbs]$ ls lk*  
    4. lkORCL  
    5. [oracle@localhost dbs]$   
    lk<sid>文件没有被删除。将它删除掉
    1. [oracle@localhost dbs]$ rm lkORCL  
    再启动数据库,成功。

    如果是Oracle进程没有关闭,用以下命令查出存在的oracle进程:
    1. [root@localhost dbs]# ps -ef|grep oracle  
    2. root      <span class="skype_c2c_print_container">2310  2358  0 16</span><span class="skype_c2c_container" dir="ltr" tabindex="-1" skype_menu_props="{"numberToCall":"+8623102358016","isFreecall":false,"isMobile":false,"isRtl":false}"><span class="skype_c2c_highlighting_inactive_common" dir="ltr" skypeaction="skype_dropdown"><span class="skype_c2c_textarea_span"><img class="skype_c2c_logo_img" src="resource://skype_ff_extension-at-jetpack/skype_ff_extension/data/call_skype_logo.png" alt=""><span class="skype_c2c_text_span">2310  2358  0 16</span><span class="skype_c2c_free_text_span"></span></span></span></span>:00 pts/0    00:00:00 su - oracle  
    3. oracle    <span class="skype_c2c_print_container">2311  2310  0 16</span><span class="skype_c2c_container" dir="ltr" tabindex="-1" skype_menu_props="{"numberToCall":"+8623112310016","isFreecall":false,"isMobile":false,"isRtl":false}"><span class="skype_c2c_highlighting_inactive_common" dir="ltr" skypeaction="skype_dropdown"><span class="skype_c2c_textarea_span"><img class="skype_c2c_logo_img" src="resource://skype_ff_extension-at-jetpack/skype_ff_extension/data/call_skype_logo.png" alt=""><span class="skype_c2c_text_span">2311  2310  0 16</span><span class="skype_c2c_free_text_span"></span></span></span></span>:00 pts/0    00:00:00 -bash  
    4. root      <span class="skype_c2c_print_container">2427  2403  0 10</span><span class="skype_c2c_container" dir="ltr" tabindex="-1" skype_menu_props="{"numberToCall":"+8624272403010","isFreecall":false,"isMobile":false,"isRtl":false}"><span class="skype_c2c_highlighting_inactive_common" dir="ltr" skypeaction="skype_dropdown"><span class="skype_c2c_textarea_span"><img class="skype_c2c_logo_img" src="resource://skype_ff_extension-at-jetpack/skype_ff_extension/data/call_skype_logo.png" alt=""><span class="skype_c2c_text_span">2427  2403  0 10</span><span class="skype_c2c_free_text_span"></span></span></span></span>:47 pts/1    00:00:00 su - oracle  
    5. ……   
    然后用kill -9命令杀掉进程
    $kill -9 <PID>
     
    总结:
    当发生1102错误时,可以按照以下流程检查、排错:

    1.如果是HA系统,检查其他节点是否已经启动实例;

    2.检查Oracle进程是否存在,如果存在则杀掉进程; 

    3.检查信号量是否存在,如果存在,则清除信号量;

    4.检查共享内存段是否存在,如果存在,则清除共享内存段; 

    5.检查锁内存文件lk<sid>和sgadef<sid>.dbf是否存在,如果存在,则删除。

    来源: www.HelloDBA.com

  • 相关阅读:
    NOI AC#62 color(树上操作)
    fenbi
    bert 压缩优化方向的论文
    bert 编程入门| bert 瘦身技巧
    行政法+刑法+民法
    Bert原理 | Bert油管视频学习法
    vscode的使用以及快捷键总结
    NG课程笔记学习记录
    古典文学+古曲+四大文明古国
    中国地理+地球上的水和大气
  • 原文地址:https://www.cnblogs.com/jxterminator/p/4026935.html
Copyright © 2011-2022 走看看