Oracle单实例数据库启动过程详解

Oracle数据库实例启动时,分成nomount、mount和open的三个阶段
1、nomout阶段,该阶段启动的前提是有参数文件,若没有参数文件,系统无法启动,在该过程中,系统分配内存、开启后台进程,同时更新alter日志文件,初始化部分v$视图。

实例nomount之前的状态:
–无实例进程
-----操作系统环境变量,查看数据库实例名称
[oracle@secdb1 admin]$ echo $ORACLE_SID
PROD

linux系统ps命令将某个进程显示出来,-e显示所有进程,-f 全格式。
[oracle@secdb1 admin]$ ps -ef|grep PROD
oracle   14890  6310  0 21:12 pts/1    00:00:00 grep PROD

-----查看alter日志信息,ls 表示列出当前目录下的文件,-l 表示开启长列表输出,打开了就会输出文件权限、引用计数、所有者、所属组、文件大小、修改日期和文件名称这些详细的信息;-t 以时间排序,最新的文件会排在上面;-r 表示反向排序、倒序输出。
[oracle@secdb1 bdump]$ ls -lrt
total 48
-rw-r----- 1 oracle oinstall  1113 Mar  4 23:15 prod_lgwr_7319.trc
-rw-r----- 1 oracle oinstall   779 Mar  5 19:42 prod_mmnl_7329.trc
-rw-r–r-- 1 oracle oinstall 40910 Mar  5 21:08 alert_PROD.log

此时启动实例到nomount状态
-----参数文件被读取;后台进程和内存结构被启动;但它们不被附加或与数据库的磁盘结构进行通信。系统在内存规划一个固定区域,用来储存用户需要的数据,以及Oracle运行时必备的系统信息,即SGA。SGA由Fixed Size、Variable Size、Database Buffers、Redo Buffers组成。
[oracle@secdb1 admin]$ sqlplus / as sysdba
SQL*Plus: Release 10.2.0.1.0 - Production on Wed Mar 5 21:15:50 2014
Copyright © 1982, 2005, Oracle.  All rights reserved.
Connected to an idle instance.
SQL> startup nomount
ORACLE instance started.
Total System Global Area  314572800 bytes
Fixed Size                  1219184 bytes
Variable Size             100664720 bytes
Database Buffers          209715200 bytes
Redo Buffers                2973696 bytes
SQL>

此时查看进程和日志信息
[oracle@secdb1 bdump]$ ls -lrt
total 52
-rw-r----- 1 oracle oinstall  1113 Mar  4 23:15 prod_lgwr_7319.trc
-rw-r----- 1 oracle oinstall   779 Mar  5 19:42 prod_mmnl_7329.trc
-rw-r–r-- 1 oracle oinstall 42513 Mar  5 21:15 alert_PROD.log  ----------------日志文件已经更新

ProcessMonitor (PMON): 该进程在用户进程出现故障时执行进程恢复,负责清理内存储区和释放该进程所使用的资源,向Oracle TNS listener注册实例信息。
memory manager(MMAN):MMAN内存管理,如果设定了 SGA自动管理,MMAN用来协调SGA内各组件的大小设置和大小调整。
DBWn,数据写进程。DBWn负责把缓冲区的脏数据写到磁盘上。
LGWR,日志写进程。LGWR是把SGA中redo log buffer的信息写到redo log file的进程。
CKPT,检查点进程。CKPT进程并不像它的名字说的那样进行checkpoint,执行checkpoint是DBWn的工作。它只是来更新数据文件头的。
System Monitor (SMON):该进程在实例启动时执行实例恢复,还负责清理不再使用的临时段。
MMON(Manageability Monitor)是数据库版本10g引入的进程,是数据库的很多自我监视和自我调整功能的支持进程。

[oracle@secdb1 bdump]$ ps -ef|grep PROD  ----------------------------系统中出现后台进程
oracle   14946     1  0 21:15 ?        00:00:00 ora_pmon_PROD
oracle   14948     1  0 21:15 ?        00:00:00 ora_psp0_PROD
oracle   14950     1  0 21:15 ?        00:00:00 ora_mman_PROD
oracle   14952     1  0 21:15 ?        00:00:00 ora_dbw0_PROD
oracle   14954     1  0 21:15 ?        00:00:00 ora_lgwr_PROD
oracle   14956     1  0 21:15 ?        00:00:00 ora_ckpt_PROD
oracle   14958     1  0 21:15 ?        00:00:00 ora_smon_PROD
oracle   14960     1  0 21:15 ?        00:00:00 ora_reco_PROD
oracle   14962     1  0 21:15 ?        00:00:00 ora_mmon_PROD
oracle   14964     1  0 21:15 ?        00:00:00 ora_mmnl_PROD
oracle   14965 14942  0 21:15 ?        00:00:00 oraclePROD (DESCRIPTION=(LOCAL=YES)(ADDRESS=(PROTOCOL=beq)))
oracle   14988  5989  0 21:17 pts/3    00:00:00 grep PROD

-----Oracle启动第一步找参数文件,根据环境变量 O R A C L E S I D 确 定 数 据 库 实 例 名 称 , 然 后 到 ORACLE_SID确定数据库实例名称,然后到 ORACLESIDORACLE_HOME/dbs目录下找spfileSID.ora文件,然后启动。如果找不到该文件,文件就寻找initSID.ora文件

如果在 O R A C L E H O M E / d b s 目 录 下 无 参 数 文 件 , 启 动 实 例 是 现 象 如 下 : [ o r a c l e @ s e c d b 1 d b s ] ORACLE_HOME/dbs目录下无参数文件,启动实例是现象如下: [oracle@secdb1 dbs] ORACLEHOME/dbs[oracle@secdb1dbs] sqlplus / as sysdba
SQL*Plus: Release 10.2.0.1.0 - Production on Wed Mar 5 21:21:19 2014
Copyright © 1982, 2005, Oracle.  All rights reserved.
Connected to an idle instance.
SQL> startup nomount
ORA-01078: failure in processing system parameters
LRM-00109: could not open parameter file ‘/u01/app/oracle/product/10.2.0/db_1/dbs/initPROD.ora’
SQL> quit
在该阶段,可以进行数据库的创建、控制文件的创建

动态参数文件、静态参数文件的生成
连接到数据库sqlplus / as sysdba
SQL>create pfile from spfile;这个命令完成后,在$ORACLE_HOME\dbs目录下就会多出来一个initSID.ora文件。
SQL>create spfile from pfile;动态参数文件损坏后,可以通过静态参数文件打开数据库,然后通过静态参数文件生成动态参数文件。

如果在实际环境中没有备份动态参数文件spfile,参数文件修改导致Oracle数据库无法open,则退出Oracle连接,重新sqlplus / as sysdba,利用这个命令SQL>create pfile from spfile;,就会在$ORACLE_HOME\dbs目录下就会多出来一个initSID.ora文件。然后vi打开initSID.ora文件,将原来更改的参数恢复原状即可。

2、mount,在该阶段,启动条件是需要有控制文件,如果控制文件丢失或者损坏,启动将会报错。此时系统会打开控制文件,从控制文件中读取数据文件及重做日志文件名称与状态,但是此时并不检查数据文件与重做日志文件的存在性。

mount之前:
SQL> select * from v$controlfile;
no rows selected

SQL> select * from v d a t a f i l e ; s e l e c t ∗ f r o m v datafile; select * from v datafile;selectfromvdatafile
              *
ERROR at line 1:
ORA-01507: database not mounted

mount之后
SQL> alter database mount;
Database altered.
SQL> select name from v$controlfile;
NAME

/u01/app/oracle/oradata/PROD/disk1/control01.ctl
/u01/app/oracle/oradata/PROD/disk2/control02.ctl

SQL> select file#,name from v$datafile;
     FILE#  name

1  /u01/app/oracle/oradata/PROD/disk1/system01.dbf
         2  /u01/app/oracle/oradata/PROD/disk1/undotbs01.dbf
         3 /u01/app/oracle/oradata/PROD/disk1/sysaux01.dbf
在该阶段,可以进行数据库的完全恢复、修改数据库的归档模式、移动和重命令数据文件
SQL> archive log list  —查看数据库归档模式
Database log mode              No Archive Mode
Automatic archival             Disabled
Archive destination            /u01/app/oracle/product/10.2.0/db_1/dbs/arch
Oldest online log sequence     3
Current log sequence           5

SQL> alter database archivelog; —修改成归档模式
SQL> alter database noarchivelog;—修改成非归档模式

如果控制文件丢失,系统报错,现象如下:
SQL> startup mount
ORACLE instance started.
Total System Global Area  314572800 bytes
Fixed Size                  1219184 bytes
Variable Size             100664720 bytes
Database Buffers          209715200 bytes
Redo Buffers                2973696 bytes
ORA-00205: error in identifying control file, check alert log for more info

3、open阶段,该阶段主要是打开数据文件、日志文件,在打开的过程中对数据文件和日志文件进行一致性检查,如果不一致,则SMON进程继续实例恢复,如果文件丢失,打开失败。
SQL> alter database open;
Database altered.

–如何数据文件丢下,打开失败
SQL> startup mount;
ORACLE instance started.
Total System Global Area  314572800 bytes
Fixed Size                  1219184 bytes
Variable Size              79693200 bytes
Database Buffers          230686720 bytes
Redo Buffers                2973696 bytes
Database mounted.
SQL> alter database open;
alter database open
*
ERROR at line 1:
ORA-01157: cannot identify/lock data file 1 - see DBWR trace file
ORA-01110: data file 1: ‘/u01/app/oracle/oradata/PROD/disk1/system01.dbf’

4、小结
 启动时分成三个步骤,1、nomount阶段,该阶段是实例启动,根据参数文件进行系统分配内存,启动后台进程。mount阶段,根据控制文件来进行数据文件和日志文件的名称和位置检查,把实例和数据库连接起来。open阶段,就是数据库打开阶段,打开是就需要检查文件是否正常,有没有发生文件丢失或者不一致的情况,丢失则报错,不一致则进行实例恢复。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值