Oracle 数据库实例启动与关闭

1.1启动流程详解

Oracle 实例启动分为三个阶段,每个阶段完成不同的初始化工作:

|-------------|----------------------|----------------------|
| 阶段 | 命令 | 完成的工作 |
| NOMOUNT | STARTUP NOMOUNT | 读取参数文件,分配 SGA,启动后台进程 |
| MOUNT | ALTER DATABASE MOUNT | 读取控制文件,定位数据文件和重做日志 |
| OPEN | ALTER DATABASE OPEN | 打开数据文件和重做日志,验证一致性 |

案例:分阶段启动排查控制文件损坏

**S --- Situation(场景):**数据库启动时报 ORA-00205: error in identifying control file,无法正常启动。

**T --- Task(任务):**通过分阶段启动定位是控制文件问题还是其他问题。

A --- Action(行动):

1、尝试启动到 NOMOUNT(测试参数文件和内存):

STARTUP NOMOUNT; -- 成功,说明参数文件和内存分配正常

2、尝试 MOUNT(测试控制文件):

ALTER DATABASE MOUNT; -- 失败,报 ORA-00205

3、检查控制文件配置:

SHOW PARAMETER CONTROL_FILES; -- 发现控制文件路径 +DATA/orcl/control01.ctl

4、检查控制文件是否存在:

ls -la +DATA/orcl/control01.ctl -- 文件不存在(ASM 磁盘组故障导致)

5、 从备份恢复控制文件:

RMAN> RESTORE CONTROLFILE FROM AUTOBACKUP;

RMAN> ALTER DATABASE MOUNT;

RMAN> RECOVER DATABASE;

RMAN> ALTER DATABASE OPEN RESETLOGS;

**R --- Result(结果):**通过分阶段启动,快速定位到控制文件损坏问题。从 RMAN 备份恢复控制文件后,数据库正常打开。

1.2、关闭模式对比

|-------------------|---------|------------|------------|
| 模式 | 新连接 | 等待会话结束 | 等待事务提交 |
| NORMAL | 拒绝 | 是 | 是 |
| IMMEDIATE | 拒绝 | 否(强制断开) | 回滚未提交事务 |
| TRANSACTIONAL | 拒绝 | 否 | 等待当前事务完成 |
| ABORT | 拒绝 | 否 | 否(直接终止) |

案例:选择合适的关闭模式

**S --- Situation(场景):**运维团队需要在 30 分钟维护窗口内完成数据库补丁升级。数据库有 200 个活跃连接,部分会话执行长事务(预计 2 小时完成)。

**T --- Task(任务):**选择合适的关闭模式,确保在维护窗口内完成关闭,同时最小化数据风险。

A --- Action(行动):

1、 评估各模式可行性:

-- NORMAL:需要等待所有会话结束,长事务需 2 小时,超时

-- IMMEDIATE:强制断开连接,回滚未提交事务,约 5 分钟

-- TRANSACTIONAL:等待当前事务完成,约 30 分钟(边界)

-- ABORT:立即关闭,但需要实例恢复

2、选择 TRANSACTIONAL 模式:

SHUTDOWN TRANSACTIONAL;

3、如果超时则使用 IMMEDIATE:

--等待 20 分钟后,仍有事务未完成

SHUTDOWN IMMEDIATE;

4、完成补丁升级后启动:

STARTUP UPGRADE; -- 升级模式

-- 执行补丁脚本

@?/rdbms/admin/catupgrd.sql --执行升级脚本

SHUTDOWN IMMEDIATE; --数据库最常用、最安全的正常关闭命令,同时保证数据一致性和完整性

STARTUP; --重新以正常模式启动数据库

**R --- Result(结果):**在 25 分钟内完成关闭和补丁升级。TRANSACTIONAL 模式等待了大部分事务完成,IMMEDIATE 模式处理了剩余长事务。数据一致性完好。

1.3、启动故障排查

案例:参数文件缺失导致启动失败

**S --- Situation(场景):**数据库启动时报 ORA-01078: failure in processing system parameters,无法进入 NOMOUNT 阶段。

**T --- Task(任务):**排查参数文件问题并恢复启动。

A --- Action(行动):

1、检查参数文件搜索顺序:

-- Oracle 按以下顺序搜索:

$ORACLE_HOME/dbs/spfile<SID>.ora

$ORACLE_HOME/dbs/spfile.ora

$ORACLE_HOME/dbs/init<SID>.ora

2、检查文件是否存在:

ls -la $ORACLE_HOME/dbs/spfile*.ora

ls -la $ORACLE_HOME/dbs/init*.ora

3、如果 SPFILE 丢失,从 PFILE 启动:

STARTUP PFILE = '/tmp/initORCL.ora';

4、重建 SPFILE:

CREATE SPFILE FROM PFILE = '/tmp/initORCL.ora';

5、正常重启:

SHUTDOWN IMMEDIATE;

STARTUP;

**R --- Result(结果):**通过检查参数文件搜索顺序,快速定位到 SPFILE 丢失问题。从 PFILE 启动后重建 SPFILE,数据库恢复正常。

相关推荐
暴躁小师兄数据学院5 小时前
【AI大数据工程师特训笔记】第05讲:关联查询
数据库·sql·oracle
倔强的石头_6 小时前
《Kingbase护城河》——跨平台环境下的数据库联调实战
数据库
lzhdim6 小时前
SQL 入门 17:MySQL 数据类型:从字符串到 JSON 的全面解析
数据库·sql·mysql·json
杨云龙UP6 小时前
Oracle RAC / ODA 生产环境指定 PDB 启动 SOP
linux·运维·数据库·oracle
kingwebo'sZone6 小时前
在Cent上安装Mysql 8.0的遇到的问题和解决办法
数据库·mysql·adb
幽络源小助理6 小时前
最新知识付费系统网站源码 PC+H5双端 附安装教程 – 幽络源源码网
大数据·数据库
小白考证进阶中7 小时前
Oracle OCP证书报考&考试全指南
数据库·oracle·oracle ocp·ocp认证·oracle认证·甲骨文认证·oracle ocp题库
Leon-Ning Liu8 小时前
【真实经验分享】 ORA-600 [qesmaGetTblSeg1]
数据库·oracle
与数据交流的路上8 小时前
MySQL 优化 -- 相关
数据库·mysql
Rooting++8 小时前
为什么mysql的表字段的collation会自动变
数据库·mysql