暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

关于Oracle的启动

Oracle工作笔记 2019-02-19
647

参考文献

  1. 《深入解析Oracle》

一、 背景介绍

Oracle数据库的启动博大精深,辛辛苦苦小半年,一朝回到解放前。温故而知新,事实上我并不懂Orace的启动。

二、 Oracle的启动

Oralc的启动包含三个步骤:
1.启动到nomount状态
2.启动到mount状态
3.启动到open状态
下面来具体说说Orace数据库的启动过程:

1. 启动到nomount状态

将数据库启动到nomout状态的过程实际就是创建数据库实例的过程。通过执行启动命令

startup nomount

可以将数据库启动到nomount状态。
当执行此命令将数据库从shutdown启动到nomount状态时,Oralce首先会查找ORACLE_HOME/dbs下面的spfile<sid>.ora文件,若没有此文件再找该目下的spfile.ora文件,没有最后找该目录下init<sid>.ora文件,若三个文件都没找到,则Oracle会无法初始化实例报错。当数据库正常nomount时,通过

show parameter pfile

命令可以查看创建实例所用的参数文件。


instance_name:数据库实例名,在RAC环境下区分各节点实例有用。一般就是环境变量ORACLE_SID,但是当在参数文件里指定了instance_name且与环境变量ORACLE_SID不同时,会出现

show parameter instance_name

select name from v$instance;

查询结果不一致的情况。这个是因为show parameter显示的是从参数文件获取的值,而v$instance视图的值从环境变量ORACLE_SID获取。Oracle在创建数据库实例时,各种进程的命名用的是从环境变量ORALCE_SID获取的值。
db_name:数据库的名字,一般会与instance_name相同,但不是必须的,instance_name只是实例名,与数据库名并无必要联系。
db_unique_name:这个在HA环境下区分主备库有用。

2. 启动到mount状态

数据库从可以执行

startup mount

直接从shutdown启动至mount状态,也可以执行

alter database mount;

从nomount状态转入mount状态。
当数据库进入mount状态时,会从先从参数文件中获取控制文件的信息,若控制文件不存在或者控制文件中记录的db_name与参数文件中不一致,启动至mount状态失败,数据库报错。正常找到并打开控制文件后,Oracle会根据控制文件中记录的数据文件信息判断数据文件是否存在,若数据文件有缺失,会在alert日志中报错,但是数据库能正常启至mount状态。

3. 启动到open状态

可以通过执行

startup 

直接将数据库由shutdown启动至open状态,或者执行

alter database open;

将数据库由mount启动至open状态。
在将数据库启动至open状态的过程中,首先会检查控制文件与数据文件中检查点计数器(checkpoint CNT)是否一致,然后会检查SCN是否一致。在数据库数据文件进行热备份时,检查点计数器会一致,但是SCN会不一致,数据库进行完热备份后需要根据重做日志对热备份的数据文件进行重做。

三、 其余

  1. v$recover_file:数据文件丢失或者需要恢复时可通过此视图查看相关信息。

  2. alter database rename file 'xxx' to 'zzz';蠢货如我又忘了如何重命名数据文件。

  3. v$pwfile_users:查看有sysdba权限的用户

  4. alter system checkpoint;手动执行检查点



本文分享自微信公众号 - Oracle工作笔记,如有侵权,请联系 service001@enmotech.com 删除。
最后修改时间:2019-12-17 11:20:35
文章转载自Oracle工作笔记,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论