luoson1 发表于 2018-9-25 13:16:23

Oracle 缺失INITORCL及ORACLE启动过程

  现象
  C:\Users\陈>sqlplus "/as sysdba"
  SQL*Plus:>
  Copyright (c) 1982, 2010, Oracle. All rights reserved.
  Connected to:
  Oracle Database 11g Enterprise Edition>
  With the Partitioning, OLAP, Data Mining and Real Application Testing options
  SQL> shutdown immediate
  Database closed.
  Database dismounted.
  ORACLE instance shut down.
  SQL> startup nomount
  ORA-01078: failure in processing system parameters
  LRM-00109: could not open parameter file 'E:\APP\CSWGGOD\PRODUCT\11.2.0\DBHOME_1
  \DATABASE\INITORCL.ORA'
  原因:缺失INITORCL.ORA
  解决方法:
  1.复制INITORCL.ORA文件
  C:\Users\陈>E:
  --------复制INITORCL.ORA备份文件
  E:\app\cswggod\product\11.2.0\dbhome_1\database>copy E:\app\cswggod\admin\orcl\p
  file\init.ora.7182012101127 INITORCL.ORA
  已复制1 个文件。
  E:\app\cswggod\product\11.2.0\dbhome_1\database>dir
  驱动器E 中的卷是Workware
  卷的序列号是027B-A992
  E:\app\cswggod\product\11.2.0\dbhome_1\database 的目录
  2012/10/10 13:34.
  2012/10/10 13:34..
  2012/08/18 10:02archive
  2012/08/18 10:04 2,048 hc_orcl.dat
  2012/10/08 15:51 1,973 INITORCL.ORA
  2.启动数据库
  C: \Users\陈>sqlplus "/as sysdba"
  SQL*Plus:>
  Copyright (c) 1982, 2010, Oracle. All rights reserved.
  Connected to:
  Oracle Database 11g Enterprise Edition>
  With the Partitioning, OLAP, Data Mining and Real Application Testing options
  SQL> startup nomount
  ORACLE instance started.
  Total System Global Area 1071333376 bytes Fixed>
  ORA-01507: database not mounted
  ORACLE instance shut down. SQL>
  SQL> startup
  ORACLE instance started.
  Total System Global Area 1071333376 bytes Fixed>
  Database opened.
  3.附录-数据库启动过程
  1)NOMOUNT
  这一步只和参数文件有关,如果在这一步就出现问题,那么通常可能是系统配置(如内核参 数等)存在问题,需要检查是否分配了足够的系统资源。
  2)MOUNT
  这一步需要从参数文件中获得控制文件位置,读取其中内容,校验数据文件的存在性。除此之外还会去校验口令文件。Oracle 缺省查找 orapw文件,如果该文件找不 到,则继续查找 orapw 文件,如果两者都不存在,数据库将出现错误。但数据为仍可以打 开。从 Oracle10g 开始,当口令文件丢失后,Oracle 将不再提示错误,只是和口令文件相关 的部分功能将无法使用。
  --------------------------------------------文件及作用---------------------------------------
  该文件在数据库启动时创建,用于操作系统对数据库的锁定。当数据库启动时获得锁定,数 据库关闭时释放。在系统出现异常时,可能数据库已经关闭,但锁定并未释放,或者因为后 台进程未正常停止等原因,会导致下次数据库无法启动。解决办法就是重启服务器,或者手工释放共享内存段。
  3)OPEN
  这一步将进行检查点和完整性的检查。如果检查全部通过,则打开数据库,否则给出错误警 告,停止打开数据库。
  -------------------------------------------------------数据库的启动验证--------------------------------------
  ○1 . 第一次检查数据文件头中的 Checkpoint CNT 是否与对应控制文件中的 Checkpoint CNT
  一致。此步骤检查用以确认数据文件是否来自同一版本,而不是从备份中恢复而来
  (在热备份模式下,数据文件检查点被冻结,但检查点计数不会被冻结,会一直修改) 在 Oracle10g 中用 8 级转储获得控制文件信息。

  SQL>>  在 Oracle9i 中用 10 级转储。
  ----------------------------------------------------------------------------------------------------------------------------
  ○2 . 第二次检查数据文件头的开始 SCN 和控制文件中记录的该文件的的结束 SCN 是否一致。如果一致,则不需要对那个文件进行恢复。
  部分控制文件转储内容:
  222 DATA FILE RECORDS
  223 ***************************************************************************

  224 (size = 428, compat>  225 last-recid= 8, old-recno = 0, last-recno = 0)
  226 (extent = 1, blkno = 11, numrecs = 100)
  227 DATA FILE #1:
  228 (name #7) /u01/app/oracle/oradata/orcl/system01.dbf

  229 creation>  230 tablespace 0, index=1 krfil=1 prev_file=0
  231 unrecoverable scn: 0x0000.00000000 01/01/1988 00:00:00
  232 Checkpoint cnt:52 scn: 0x0000.0007ba16 02/18/2011 16:30:22
  233 Stop scn: 0xffff.ffffffff 02/16/2011 11:07:26
  234 Creation Checkpointed at scn: 0x0000.00000009 06/30/2005 19:10:11
  235 thread:0 rba:(0x0.0.0)
  236 enabled threads: 00000000 00000000 00000000 00000000 00000000 00000000
  ----------------------------------------------------------------------------------------------------------------------------
  在数据库出现问题时,提示中给出的可能是不完整的信息,而告警日志中则记录了完整的错 误过程和错误号。
  说明:
  控制文件中记录的 SCN 指最后一次成功完成的检查点 SCN; 数据文件头中的记录的 SCN 指数据文件最后一次成功完成的检查点 SCN;
  此外,在控制文件和数据文件头都记录一个检查点计数(chkpt cnt),而且数据文件头还记录了一个 控制文件检查点计数(ctl cnt)。但这个 ctl cnt 要比控制文件中的 ctl cnt 小 1。这是因为,当检查
  点更新控制文件和数据文件头上的 chkpt cnt 信息时,在更新控制文件之前,可以
  获得当前的 ctl cnt
  ,这个信息被记入了数据文件。之所以这么做,是因为不能保证更新控制文件上的 chkpt cnt 一定 会成功,记录之前的 ctl cnt 可以确保上一次的 chkpt cnt 是成功 完成的。

页: [1]
查看完整版本: Oracle 缺失INITORCL及ORACLE启动过程