ORACLE无法OPEN,处理三板斧

mount下先查询数据文件头的检查点是否一致

查询 v$datafile_header ,CHECKPOINT_CHANGE#均一致,FUZZY为YES

sql 复制代码
SQL> select file#, fuzzy, to_char(CHECKPOINT_CHANGE#) from v$datafile_header;

1)对于open resetlogs时数据文件中有脏数据的情况,可以设置

sql 复制代码
_allow_resetlogs_corruption= TRUE

来规避。

2)如果出现ORA-01555错误,导致数据库无法open,可以设置

sql 复制代码
_CORRUPTED_ROLLBACK_SEGMENTS
undo_management = 'MANUAL'

的方式来规避

3)出现ORA-600 [2662]错误时,先通过多次重启open的方法来观察Current SCN BASE增长速度。

如果Current SCN BASE和Current SCN BASE相差不远,重启几次数据库就课可以打开。

4)如果Current SCN BASE和Current SCN BASE相差很远,mount之后先

sql 复制代码
alter session  set events '10015 trace name adjust_scn level 10';

加速增长。

然后open

5)如果加入10015事件adjust_scn以后,Current SCN BASE增长还是很慢,有些版本必须加入

sql 复制代码
_allow_error_simulation  = TRUE

才能使10015事件生效

6)如果Current SCN BASE增长还是很慢,加入

sql 复制代码
_smu_debug_mode = 268435456

直接增长SCN WRAP的方法来加速

7)还可以通过_minimum_giga_scn来加速(本案例未使用)

  1. 如果SCN号一致以后报错ORA-600[6006],ORA-600[4137]的话,需要添加参数
sql 复制代码
*.event="10513 trace name context forever,level 2"
*.db_block_checking=false

9) 对于open resetlogs打开以后的数据库,最好将业务用户导出以后重建数据库,以防止数据库出现不可预知的错误。ORACLE官方建议是open resetlogs以后需要重建数据库。

参数,事件,错误说明:

1)_ALLOW_RESETLOGS_CORRUPTION=true:允许resetlogs时数据文件中有脏数据

2)_CORRUPTED_ROLLBACK_SEGMENTS:将回滚段标记为损坏

3)ORA-600 [2662] [a] [b] [c] [d] [e]:

Arg [a] Current SCN WRAP:当前(控制文件)的SCN WRAP

Arg [b] Current SCN BASE:当前(控制文件)的SCN BASE

Arg [c] dependent SCN WRAP:目标SCN WRAP

Arg [d] dependent SCN BASE:目标SCN BASE

Arg [e] Where present this is the DBA where the dependent SCN came from.

SCN可以用十六进制表示0Xffff.ffffffff。为了方便,oracle把前面的4个字节表示scn wrap,后面的8个字节表示scn base。scn最低值是0X0000.00000000,最高值是0Xffff.ffffffff。高位是scn wrap,低位是scn base。

SCN= (SCN_WRAP * 4294967296) + SCN_BASE,当SCN_BASE足够大时,SCN_WRAP就会加1,也就是说SCN_WRAP是SCN的高位,SCN_BASE是SCN的低位。

4294967296=2^32

4)10015 ADJUST_SCN事件:加速Current SCN BASE增长

5)_allow_error_simulation=true,该值设为false时会阻止ADJUST_SCN事件

6)_smu_debug_mode= 268435456,增长SCN WRAP,这个参数需要和_allow_error_simulation=true同时使用

7)_minimum_giga_scn=n:把SCN向前推进nG,只有Current SCN和dependent SCN相差nG时这个参数才起效,否则无效。

8)*.event="10513 trace name context forever,level 2"禁止SMON回滚恢复事务

相关推荐
运维小文9 分钟前
PQL查询和监控各类中间件
数据库·云原生·中间件·prometheus·监控
网安墨雨16 分钟前
信息安全意识之安全组织架构图
数据库·安全·php
大小科圣22 分钟前
Tomcat介绍及部署
运维·服务器
补三补四36 分钟前
Yashan DB 实例管理
数据库·oracle
好多知识都想学1 小时前
第二章Linux 命令概述
linux·运维·服务器
wo3258661451 小时前
浪潮英政服务器CS5420H2配置阵列时报错The reguested command has inualid arguments.解决方法
运维·服务器
熊峰峰1 小时前
Linux第0节:Linux环境的搭建
linux·运维·服务器
一点多余.1 小时前
nginx的使用
运维·nginx
yqcoder1 小时前
Express + MongoDB + multer 解决文件上传 originalname 中文乱码
数据库·mongodb·express
鸭梨山大。1 小时前
linux命令-iptables与firewalld 命令详解
linux·运维·网络