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,数据库恢复正常。

相关推荐
Nturmoils3 小时前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波7 小时前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
倔强的石头_1 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
倔强的石头_4 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab5 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence5 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神5 天前
三、用户与权限管理
数据库·mysql
麦聪聊数据6 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_6 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡6 天前
【MySQL数据库】数据类型与表约束
数据库·mysql