ITPub博客

首页 > 数据库 > Oracle > 深入理解ORACLE启动过程

深入理解ORACLE启动过程

Oracle 作者:danmom 时间:2014-02-12 15:53:45 0 删除 编辑


深入理解ORACLE启动过程

ORACLE SERVER由实例(Instance)和数据库(database)组成,而实例是由一组后台进程和一块共享内存区域(sga)组成,而后台进程是数据库和操作系统进行交互的通道,后台进程的命名由ORACLE_SID决定,ORACLE根据ORACLE_SID来寻找参数文件启动实例。数据库是指存储在磁盘上的一组物理文件。

 

ORACLE启动分3个过程:

NOMOUNT状态:启动实例

MOUNT状态:打开控制文件

OPEN状态:打开控制文件中描述的文件

 

NOMOUNT状态:

ORACLE需要寻找SPFILE(oracle 10g默认,pfile也可以)文件,来创建实例和分配内存。

 

MOUNT状态:

在此状态需要打开控制文件,而控制文件中包含日志文件,数据文件的位置信息,检查点信息等重要信息。

在ORACLE9i中,丢失口令文件会报错,可以通过orapw工具重建。在oracle 10g不会报错,通过v$pwfile_users视图查询。

lk_文件在数据库启动时创建,用于操作系统对数据库的锁定。

口令文件存在$ORACLE_HOME/dbs

 

alter system set controlfile='控制文件路径' scope=spfile;

alter system set lock_name_space=orcl  scope=spfile;

 

重建控制文件:

SQL>startup nomount;

SQL>create controlfile reuse database "orcl" noresetlogs archivelog

maxlogfiles 5

maxlogmembers 3

maxdatafiles 100

maxinstances 1

maxloghistory 1134

logfile

group 3 '/data/app/oracle/oradata/orcl/redo03.log' size 10m,

group 4 '/data/app/oracle/oradata/orcl/redo04.log' size 10m,

group 5 '/data/app/oracle/oradata/orcl/redo05.log' size 10m

datafile

'/data/app/oracle/oradata/orcl/system01.dbf',

'/data/app/oracle/oradata/orcl/undotbs01.dbf',

'/data/app/oracle/oradata/orcl/sysaux01.dbf'

character set zhs16gbk;

 

OPEN状态

首先会检查数据文件头中检查点计数与控制文件中检查点计数是否一致。其次检查数据文件头的开始SCN和控制文件中记录该文件的结束SCN是否一致,如果控制文件中结束的SCN等于数据文件头中开始的SCN,说明不需要恢复。

 

SQL>show parameter backgroud_dump_dest;

如果数据库中的某个文件丢失,那么在MOUNT阶段不会在前台显示告警日志,会记录在alter_.log中。 





Oracle  的启动需要经历四个状态,SHUTDOWN NOMOUNT MOUNT OPEN

 

 

 

SHUTDOWN状态                                         

第一状态没什么好解释的,oracle的所有文件都静静的躺在磁盘里,一切都还未开始,属于关机状态

 

 

NOMOUNT状态                            

Starting the instance (nomount)

 Reading the initialization file from $ORACLE_HOME/dbs in the following order:

-first  spfileSID.ora

-if not found then, spfile.ora

-if not found then, initSID.ora

Specifying the PFILE parameter with STARTUP overrides the default behavior.

 Allocating the SGA

 Starting the background processes 

 Opening the alertSID.log file and the trace files

The  database must be named with the DB_NAME parameter either in the initialization 

Parameter file or in the STARTUP command.

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

读取环境变量下dbs目录下的参数文件(spfile/pfile

 [ora10@localhost dbs]$ pwd

/ora10/product/10.2.0/db_1/dbs

[ora10@localhost dbs]$ ll

-rw-r----- ora10 dba  3584 07-19 22:07 spfilechongshi.ora

-rw-r----- ora10 dba  3584 07-23 22:00 spfile.ora

-rw-r--r-- ora10 dba  1106 07-19 21:47 initchongshi.ora

查找参数文件的顺序如上面列表的,读取优先级

spfilechongshi.ora spfile.ora>initchongshi.ora  

如果三个文件都找不到的话,那么将启动失败。

* 启动算法,分配内存

* 启动后台进程

* 开放alertSID.log文件和跟踪文件

复制代码

[ora10@localhost dbs]$ sqlplus 

SQL*Plus: Release 10.2.0.1.0 - Production on Tue Jul 24 22:33:54 2012

Copyright (c) 1982, 2005, Oracle.  All rights reserved.

Enter user-name: /as sysdba

Connected to an idle instance.

SQL> startup nomount;

ORACLE instance started.

Total System Global Area  205520896 bytes

Fixed Size                  1218532 bytes

Variable Size              79693852 bytes 

Database Buffers          121634816 bytes 

Redo Buffers                2973696 bytes 
复制代码

现在就处在一个nomount状态。

 

 

 mount状态                                                  

Mounting database includes the following tasks: 

Associating database with  previously started instance 

Locating and opening the control files specified in the parameter file 

Reading the control files to obtain the names and status of the data files and online redo log files.However,no checks are performed to verify the existence of the data files and online redo log files at this time. 

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

* 把一个数据库和启动的实例关联起来 

在参数文件(spfile/pfile)中找到控制文件进行读取 

查看参数文件: 

[ora10@localhost dbs]$ strings spfileora10.ora more 

......

*.control_files='/ora10/product/oradata/ora10/control01.ctl','/ora10/product/ora 

data/ora10/control02.ctl','/ora10/product/oradata/ora10/control03.ctl' 

....... 

控制文件: 

[ora10@localhost ~]$ cd /ora10/product/oradata/ora10/ 

[ora10@localhost ora10]$ ll 

总计 954196 

-rw-r----- ora10 dba   7061504 07-23 23:01 control01.ctl 

-rw-r----- ora10 dba   7061504 07-23 23:01 control02.ctl 

-rw-r----- ora10 dba   7061504 07-23 23:01 control03.ctl 

* 读取控制文件,获得的数据文件和联机重做日志文件,然而,在这个时候没有进行检查以验证存在的数据文件和联机重做日志文件 

复制代码

[ora10@localhost dbs]$ sqlplus 

SQL*Plus: Release 10.2.0.1.0 - Production on Tue Jul 24 23:02:28 2012 

Copyright (c) 1982, 2005, Oracle.  All rights reserved. 

Enter user-name: /as sysdba 

Connected to an idle instance. 

SQL> startup mount; 

ORACLE instance started. 

Total System Global Area  205520896 bytes 

Fixed Size                  1218532 bytes 

Variable Size              79693852 bytes 

Database Buffers          121634816 bytes 

Redo Buffers                2973696 bytes 

Database mounted. 
复制代码

现在进入了数据库的mount状态,我们通过mount启动的时候,下面会多一句提示“Database mounted.” 数据库准备就绪。

 

 

open状态                                                 

  opening the database includes the following tasks 

opening the online data log files 

opening the onling redo log files 

  If any of the datafiles or noline redo log files are not present when you attempt to open the database ,the oracle server returns an error.

  During this final stage,the oracle server verfies that all the data files and online redo log files can be opened and checks the consistency of the database If necessary the SMON  background process initiates instance recovery.

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

打开数据库包括下列任务: 

打开在线数据日志文件 

打开联机重做日志文件 

    如果任何数据文件或非线性重做日志文件不存在,当您试图打开的数据库,服务器返回错误。 

在这最后阶段,该服务器验证所有数据文件和联机重做日志文件可以打开并检查数据库的一致性。如果需要,该系统监控进程开始实例恢复。

 

复制代码

  [ora10@localhost dbs]$ sqlplus /nolog
  
  SQL*Plus: Release 10.2.0.1.0 - Production on Wed Jul 25 21:50:55 2012
  
  Copyright (c) 1982, 2005, Oracle.  All rights reserved.
  
  SQL> conn /as sysdba
  Connected to an idle instance.
  SQL> startup
  ORACLE instance started.
  
  Total System Global Area  205520896 bytes
  Fixed Size                  1218532 bytes
  Variable Size              79693852 bytes
  Database Buffers          121634816 bytes
  Redo Buffers                2973696 bytes
  Database mounted.
  
  Database opened.
复制代码

   在上面的命令中,startup后面不加其它信息的话,系统会为我们直接启动到第4个状态。

 

 

数据库关闭的三种方式

 

1、shutdown normal  
正常方式关闭数据库。 


2、shutdown immediate  
立即方式关闭数据库。  
在SVRMGRL中执行shutdown immediate,数据库并不立即关闭,  
而是在Oracle执行某些清除工作后才关闭(终止会话、释放会话资源),  
当使用shutdown不能关闭数据库时,shutdown immediate可以完成数据库关闭的操作。 


3、shutdown abort  
直接关闭数据库,正在访问数据库的会话会被突然终止,  
如果数据库中有大量操作正在执行,这时执行shutdown abort后,重新启动数据库需要很长时间。

<!-- 正文结束 -->

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/22477960/viewspace-1116839/,如需转载,请注明出处,否则将追究法律责任。

上一篇: 没有了~
下一篇: 没有了~
请登录后发表评论 登录
全部评论

注册时间:2009-09-05