cdb数据库强起流程

环境模拟

因为手头没有19.3的环境,用了一个centos 7.9下的18.3的cdb环境,开启了归档

在pdb中创建表,模拟构造数据

然后删除redo log来模拟损坏

模拟插入的过程,及错误时的报错

SQL> create table t(x int);

Table created.

SQL> begin

for i in 1..1000000 loop

insert into t values(i);

commit;

end loop;

end;  2    3    4    5    6 

  7  /

^Cbegin

*

ERROR at line 1:

ORA-12152: TNS:unable to send break message

大致流程

  1. 配置参数、事件启动
  2. Alter database open [resetlogs];+alter database recover usning bakcup controlfle;
  3. Undo使用manual
  4. 处理undo表空间
  5. 其他强起的伴生问题处理

针对性错误

ORA-00313

SQL> startup

ORACLE instance started.

Total System Global Area 1593835440 bytes

Fixed Size                  8896432 bytes

Variable Size             956301312 bytes

Database Buffers          620756992 bytes

Redo Buffers                7880704 bytes

Database mounted.

ORA-00313: open failed for members of log group 2 of thread 1

ORA-00312: online log 2 thread 1: '/opt/oracle/oradata/ORCLCDB/redo02.log'

ORA-27037: unable to obtain file status

Linux-x86_64 Error: 2: No such file or directory

Additional information: 7

解决办法

*._allow_resetlogs_corruption=true

create pfile from spfile;

vi /opt/oracle/product/18c/dbhome_1/dbs/initORCLCDB.ora

*._allow_resetlogs_corruption=true

startup mount pfile='/opt/oracle/product/18c/dbhome_1/dbs/initORCLCDB.ora'

ORA-00600: [kcbzib_kcrsds_1]

SQL> alter database open resetlogs;

alter database open resetlogs

*

ERROR at line 1:

ORA-00603: ORACLE server session terminated by fatal error

ORA-01092: ORACLE instance terminated. Disconnection forced

ORA-00704: bootstrap process failure

ORA-00704: bootstrap process failure

ORA-00600: internal error code, arguments: [kcbzib_kcrsds_1], [], [], [], [],

[], [], [], [], [], [], []

Process ID: 5529

Session ID: 237 Serial number: 37189

解决办法  

’ *.event='21307096 trace name context forever, level 3'

vi /opt/oracle/product/18c/dbhome_1/dbs/initORCLCDB.ora

*._allow_resetlogs_corruption=true

*.event='21307096 trace name context forever, level 3'

ORA-00600: [4194]

【4193】【4194】【4197】都是同类undo问题

SQL> alter database open ;

alter database open

*

ERROR at line 1:

ORA-00603: ORACLE server session terminated by fatal error

ORA-01092: ORACLE instance terminated. Disconnection forced

ORA-00600: internal error code, arguments: [4194], [13], [16], [], [], [], [],

[], [], [], [], []

Process ID: 6121

Session ID: 237 Serial number: 52596

解决办法

*.undo_management=manual

vi /opt/oracle/product/18c/dbhome_1/dbs/initORCLCDB.ora

*._allow_resetlogs_corruption=true

*.event='21307096 trace name context forever, level 3'

*.undo_management=manual

后续收尾

重建undotbs

SQL> startup mount pfile='/opt/oracle/product/18c/dbhome_1/dbs/initORCLCDB.ora';

ORACLE instance started.

Total System Global Area 1593835440 bytes

Fixed Size                  8896432 bytes

Variable Size             956301312 bytes

Database Buffers          620756992 bytes

Redo Buffers                7880704 bytes

Database mounted.

SQL> alter database open;

SQL> show pdbs;

    CON_ID CON_NAME                       OPEN MODE  RESTRICTED

---------- ------------------------------ ---------- ----------

         2 PDB$SEED                       READ ONLY  NO

         3 ORCLPDB1                       MOUNTED

         4 TEST                           MOUNTED

Database altered.

SQL> alter pluggable database test open;

Pluggable database altered.

SQL> alter session set container=test;

Session altered.

SQL> select * from t;

select * from t

              *

ERROR at line 1:

ORA-00942: table or view does not exist

表t完全丢失了

检查undo段情况,这次模拟运气不好,没有损坏的undo段,这种时候直接替换undotbs就可以了

SQL> select SEGMENT_ID,SEGMENT_NAME,STATUS,TABLESPACE_NAME from dba_rollback_segs where status not in('ONLINE','OFFLINE');

no rows selected

SQL>

SQL>

SQL> select KTUXEUSN,KTUXESLT,KTUXESTA,KTUXECFL,KTUXESIZ from x$ktuxe where KTUXESTA='ACTIVE' and KTUXECFL='DEAD';

no rows selected

SQL> drop tablespace UNDOTBS1;

Tablespace dropped.

SQL> create undo tablespace UNDOTBS1 datafile '/opt/oracle/oradata/ORCLCDB/undotbs1.dbf' size 1g autoextend on;

Tablespace created.

如果有undo段损坏,使用参数

*._corrupted_rollback_segments=(_SYSSMU4_xxxxxxx$)

重启,然后舍弃undotbs1,再重建

伴生的错误ORA-00600:[kdsgrp1]

Alert日志中,关闭sqlplus时会出现

ORA-00600: internal error code, arguments: [kdsgrp1], [], [], [], [], [], [], [], [], [], [], []

ORA-06512: at "SYS.DBMS_SPD_INTERNAL", line 134

ORA-06512: at "SYS.DBMS_SPD", line 257

ORA-06512: at "SYS.DBMS_SPD", line 333

ORA-06512: at line 1

排查完是sys.COL_USAGE$有损坏。影响不大。正常流程这个应该是将强起的库导出再重建。毕竟内置的很多表损坏不可知。

总结

流程上11g的强起区别不大,ora600[2662]、[2663]变成[kcbzib_kcrsds_1],本质还是一致性问题,还是需要推scn。

核心事件

event=21307096 这个事件包含整个12c的生命周期了。从12.1-19都能用。

参考:

Force Open Database after applying Patch 21307096 (Doc ID 2674196.1)

Step by step to resolve ORA-600 4194 4193 4197 on database crash (Doc ID 1428786.1)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/171881.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

虹科分享 | AR世界揭秘:从二维码的起源到数据识别与位姿技术的奇妙融合!

引言:探索AR的神奇世界,我们将从二维码的诞生谈起。在这个科技的海洋中,二维码是如何帮助AR实现数据获取与位姿识别的呢?让我们一起揭开这层神秘的面纱! 一、二维码的由来 二维码是将数据存储在图形中的技术&#xff…

Python | CAP - 累积精度曲线分析案例

CAP通常被称为“累积精度曲线”,用于分类模型的性能评估。它有助于我们理解和总结分类模型的鲁棒性。为了直观地显示这一点,我们在图中绘制了三条不同的曲线: 一个随机的曲线(random)通过使用随机森林分类器获得的曲线…

Gee教程1.HTTP基础

标准库启动web服务 Go语言内置了 net/http库,封装了HTTP网络编程的基础的接口。这个Web 框架便是基于net/http的。我们先回顾下这个库的使用。 package mainimport ("fmt""log""net/http" )func main() {//可以写成匿名函数(lambda…

【数据结构初阶】树,二叉树

树,二叉树 1.树概念及结构1.1树的概念1.2 树的相关概念1.3 树的表示1.4 树在实际中的运用(表示文件系统的目录树结构) 2.二叉树概念及结构2.1概念2.2现实中的二叉树2.3 特殊的二叉树2.4 二叉树的性质2.5 二叉树的存储结构 1.树概念及结构 1.…

STM32-SPI3控制MCP3201、MCP3202(Sigma-Delta-ADC芯片)

STM32-SPI3控制MCP3201、MCP3202(Sigma-Delta-ADC芯片) 原理图手册说明功能方框图引脚功能数字输出编码与实值的转换分辨率设置与LSB最小和最大输出代码(注) 正负符号寄存器位MSB数字输出编码数据转换的LSB值 将设备输出编码转换为…

SQL JOIN 子句:合并多个表中相关行的完整指南

SQL JOIN JOIN子句用于基于它们之间的相关列合并来自两个或更多表的行。 让我们看一下“Orders”表的一部分选择: OrderIDCustomerIDOrderDate1030821996-09-1810309371996-09-1910310771996-09-20 然后,看一下“Customers”表的一部分选择&#xff…

单片机学习5——外部中断程序

#include<reg52.h>unsigned char a; sbit lcden P3^4;void main() {lcden0;EA1;EX01;IT00;a0xF0; //点亮4位小灯while(1){P1a;} }//中断服务程序 void ext0() interrupt 0 // 0 表示的是外部中断源0 {a0x0f; // 中断处理完&#xff0c;再返回主…

2018年10月4日 Go生态洞察:参与2018年Go公司问卷调查

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…

系列十八、Spring bean线程安全问题

一、概述 我们知道Spring中的bean&#xff0c;默认情况下是单例的&#xff0c;那么Spring中的bean是线程安全的吗&#xff1f;这个需要分情况考虑&#xff0c;bean中是否存在成员变量&#xff1f;bean中的成员变量是怎么处理的&#xff1f;...&#xff0c;针对bean的状态会有不…

【C++】类和对象——拷贝构造和赋值运算符重载

上一篇我们讲了构造函数&#xff0c;就是对象实例化时会自动调用&#xff0c;那么&#xff0c;我们这里的拷贝构造在形式上是构造函数的一个重载&#xff0c;拷贝构造其实也是一种构造函数&#xff0c;那么我们就可以引出这里的规则 1.拷贝构造函数的函数名必须与类名相同。 2.…

数据结构——带头循环双向链表(List)

1、带头双向循环链表介绍 在上一篇博客中我们提到了链表有三个特性&#xff0c;可以组合成为8种不同类型的链表。单链表是其中比较重要的一种&#xff0c;那么这次我们选择和带头双向循环链表会会面&#xff0c;这样我们就见识过了所有三种特性的呈现。 带头双向循环链表&#…

安卓使用MediaRecorder录制音频的详细使用

安卓使用MediaRecorder录制音频的详细使用 文章目录 安卓使用MediaRecorder录制音频的详细使用引言使用 MediaRecorder 的步骤常见问题及解决思路无法访问存储卡目录录制的音频文件没有声音录制过程中出现异常MediaRecorder无法正常启动录制的音质或者画质很差录制的文件无法播…

Object.is和====和==的区别

Object.is() 方法和比较操作符 、 用于比较两个值的相等性&#xff0c;但它们在比较方式和行为上有一些区别。Object.is() 方法是严格相等比较&#xff0c;而 操作符也是严格相等比较&#xff0c;但 操作符是相等比较。 严格相等比较&#xff08; &#xff09; 要求比较的…

HONOR荣耀MagicBook 15 2021款 锐龙版R5(BMH-WFQ9HN)原厂Windows11预装OEM系统含F10智能还原

链接&#xff1a;https://pan.baidu.com/s/1faYtC5BIDC2lsV_JSMI96A?pwdj302 提取码&#xff1a;j302 原厂系统Windows11.22H2工厂模式安装包,含F10一键智能还原&#xff0c;自带所有驱动、出厂主题壁纸、系统属性专属LOGO标志、Office办公软件、荣耀 电脑管家等预装程序 …

process control 化学工程 需要用到MATLAB的Simulink功能

process control 化学工程 需要用到MATLAB的Simulink功能 所有问题需要的matlab simulink 模型 WeChat: ye1-6688 The riser tube brings in contact the recirculating catalyst with the feed oil, which then vaporizes and splits to lighter components as it flows up th…

服务器下db(数据库)的执行

1、查看 select * from xxxx&#xff08;表名&#xff09; where xxx&#xff08;列表&#xff09;1 and.......正常写就行 2、插入 如果你想要在 SELECT INSERT INTO … SELECT 语句中将部分列保持不变,只改变一两列的值,可以在 语句中直接设置目标列的值,而其他列从源表中…

【代码随想录】算法训练计划31

贪心 1、455. 分发饼干 题目&#xff1a; 假设你是一位很棒的家长&#xff0c;想要给你的孩子们一些小饼干。但是&#xff0c;每个孩子最多只能给一块饼干。 对每个孩子 i&#xff0c;都有一个胃口值 g[i]&#xff0c;这是能让孩子们满足胃口的饼干的最小尺寸&#xff1b;并且…

【C++】类型转换 ③ ( 重新解释类型转换 reinterpret_cast | 指针类型数据转换 )

文章目录 一、重新解释类型转换 reinterpret_cast1、指针数据类型转换 - C 语言隐式类型转换报错 ( 转换失败 )2、指针数据类型转换 - C 语言显示类型强制转换 ( 转换成功 )3、指针数据类型转换 - C 静态类型转换 static_cast ( 转换失败 )4、指针数据类型转换 - C 重新解释类型…

Simulink 的代数环

代数环, 就是由于模型的输出反馈到模块或子系统先的某个输入端, 如果这个输入是直接馈入的, 那么二者在同一个采样点内需得到求解, 但又互相依赖, 哪一方都不能完成求解过程, 使得解算器无法解算导致错误产生, 这样的情况称为代数环。 一旦 Simulink 遇到代数环, 将根据 Confi…

Binlog vs. Redo Log:数据库日志的较劲【高级】

&#x1f38f;&#xff1a;你只管努力&#xff0c;剩下的交给时间 &#x1f3e0; &#xff1a;小破站 Binlog vs. Redo Log&#xff1a;数据库日志的较劲【高级】 前言第一&#xff1a;事务的生命周期事务的生命周期Binlog和Redo Log记录事务的一致性和持久性Binlog的记录过程R…