ORACLE启动过程

原创 2013年12月03日 15:52:33

 

数据库启动过程中有3个状态:nomountmountopen

通过如下视图可查看数据库的当前状态:

 

select open_mode from v$database; 

               --数据库状态为nomount时查询报错:database not mounted

select  status from v$instance;   

              --数据库为nomount时,值为STARTED

      mounted    ------mount状态

      open         -------open状态

 

1、nomount状态

       Oracle首先到 $ORACLE_HOME/dbs windowns$ORACLE_HOME/database目录下】按顺序寻找下列文件,如果找到了就启动实例,不继续往下找了:

       1spfile<ORACLE_SID>.ora

       2spfile.ora

       3init<ORACLE_SID>.ora

如果上述三个文件都没有找到,则报如下错误:

SQL> startup nomount          

ORA-01078: failure in processing system parameters

LRM-00109:could not open parameter file '/u01/app/oracle/product/11.2.0/dbhome_1/dbs/initmydb.ora'

**提示的是找不到最后一个文件,表明前面两个已经找过了。

 

数据库启动到nomount的过程中,会根据spfielpfile中的参数来分配内存、创建后台进程,实例被创建。

 

可通过如下命令来查看ORACLE最终是使用哪个参数文件来创建实例:

SQL> show parameter spfile

 

NAME                                 TYPE        VALUE

------------------------------------ ----------- ------------------------------

spfile                               string      /u01/app/oracle/product/11.2.0

                                                 /dbhome_1/dbs/spfilemydb.ora

 

参数文件中最少必须设置DB_NAME参数,有这个参数,数据库就能启动。

也可以查看alert日志来确认ORACLE实例在启动的过程中使用的是哪个参数文件:

[oracle@xsh trace]$ tail  -f   alert_mydb.log

Using parameter settings in server-side spfile /u01/app/oracle/product/11.2.0/dbhome_1/dbs/spfilemydb.ora

 

 

如果数据库无法启动到nomount状态,多半是OS的问题,例如补丁没打好等。

 

此时无法建立远程连接,可使用如下命令修改数据库到mount状态:

Alter database mount;

 

   

2、mount状态

此时ORACLE根据参数文件中的control_files参数找到控制文件的位置,然后根据控制文件中的信息对其中记录的各数据文件进行存在性判断,如果控制文件中记录的数据文件实际不存在,则启动过程中会报错。

可以通过如下命令来查看控制文件的位置

SQL> show parameter control_files

 

   此时只有sys账户以sysdba的身份才能远程登陆,可用如下命令修改数据库至open状态:

Alter database open;

 

3、open状态

此时ORACLE装载控制文件中记录的数据文件,此时有权限的账户都可以进行远程访问。

oracle启动参数文件顺序解释

oracle实例启动的参数文件选择顺序为spfile$ORACLE_SID.ora -> spfile.ora -> init$ORACLE_SID.ora。 下面做实验验证。 [oracle@lo...
  • w1346561235
  • w1346561235
  • 2016年05月25日 23:20
  • 1250

Oracle存储过程的事务

1.Oracle事务不会自动提交。通常情况下,oralce将整个存储过程作为一个事务整体,整个过程内的事务,要么都提交,要么都回滚。 2.如果过程内部使用了commit命令或rollback命令,则存...
  • yuhualee
  • yuhualee
  • 2014年03月05日 19:21
  • 3568

11g的ohasd无法随机启动

在Oracle Linux Server release 6.2下安装11.2.0.1的grid,安装的时候,顺利完成(可能最后执行root.sh的时候有报错,但是没注意到),等安装完重启主机,发现c...
  • shaochenshuo
  • shaochenshuo
  • 2014年10月21日 14:54
  • 2066

oracle 启动过程详解

  • 2010年10月08日 09:50
  • 50KB
  • 下载

oracle 启动过程

  • 2010年04月28日 08:00
  • 202KB
  • 下载

redhat as5 安装oracle 10g 并自启动详细安装过程,亲手通过验证

1. 系统组件 GNOME Desktop Environment Editors Graphical Internet Text-based Internet Develop...
  • zylcon
  • zylcon
  • 2013年03月06日 18:00
  • 542

Oracle Startup / Shutdown启动和关闭过程详解(概念)

对于大多数Oracle DBA来说,启动和关闭Oracle数据库最常用的方式就是在命令行方式下的Server Manager。从Oracle 8i以后,系统将Server Manager的所有功能都集...
  • HXC_HUANG
  • HXC_HUANG
  • 2017年08月07日 14:12
  • 167

深入理解ORACLE启动过程

原文地址:http://blog.chinaunix.net/uid-20682026-id-3248609.html深入理解ORACLE启动过程 ORACLE SERVER由实例(Instance...
  • lijingkuan
  • lijingkuan
  • 2016年03月04日 10:11
  • 137

一次RAC环境下服务器故障重启后ORACLE启动过程

由于服务器的硬件估计出了点问题(后来硬件服务商确认了确实有问题) 导致数据库从某个时刻开始,总是莫名其妙的出错,大都是与磁盘I/O错误之类相关的问题; 比如归档日志出错,解决问题后仍然莫名其妙的无法写...
  • eva_1st
  • eva_1st
  • 2015年12月28日 18:12
  • 977

Oracle 11G DataGuard生产环境重新启动详细过程

场景,重启数据库,不重启linux系统,所以不用考虑监听程序,#linux输入lsnrctl start1 数据库关闭1.1 关闭主库SHUTDOWN IMMEDIATE;SQL> SHUTDOWN ...
  • mchdba
  • mchdba
  • 2014年07月10日 10:01
  • 2220
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:ORACLE启动过程
举报原因:
原因补充:

(最多只允许输入30个字)