ORA-01102 解决思路

2014-11-24 18:01:14 · 作者: · 浏览: 0

一、出现的现象:


SQL> conn /as sysdba


Connected to an idle instance.


SQL> startup


Total System Global Area 276824064 bytes


Fixed Size 778736 bytes


Variable Size 137371152 bytes


Database Buffers 138412032 bytes


Redo Buffers 262144 bytes


ORA-01102: cannot mount database in EXCLUSIVE mode


二、解决的方法:


解决方法一:重启机器,能够解决(注意,需要察看环境变量中SID和自己创建数据库的SID是否一致)


解决方法二:位于ORALCE_HOME下的dbs目录下,发现是lk文件造成的。


使用fuser -k lk 就解决。


三、产生原因分析:


由于我在创建数据库的时候,环境变量中的设置的SID和我实际创建数据库的SID不一致,所以造成了数据库误认为,我同时运行两个实例。lk实际就是防止两个实例同时并发运行。


四、解决此类错误的流程:


当发生1102错误时,可以按照以下流程检查、排错:


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


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


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


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


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