数据库不一致时启动数据库

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 本文介绍数据库不一致时如何启动数据库。

本文介绍数据库不一致时如何启动数据库。

环境准备

创建一个user2表空间,然后人为的制造这个表空间的数据文件和其它数据文件不一致:

SQL> create tablespace user2 datafile '/u01/app/oracle/oradata/ORCL/users02.dbf' size 10m;
Tablespace created.
SQL> create table user2_t1 tablespace user2  as select object_id,object_name from dba_objects;
Table created.
SQL> ! cp /u01/app/oracle/oradata/ORCL/users02.dbf /u01/app/oracle/oradata/ORCL/users02.dbf.bk
SQL> alter system checkpoint;
System altered.
SQL> shutdown abort
ORACLE instance shut down.
SQL> ! cp /u01/app/oracle/oradata/ORCL/users02.dbf.bk /u01/app/oracle/oradata/ORCL/users02.dbf
SQL> startup 
ORACLE instance started.
Total System Global Area  771747984 bytes
Fixed Size      8900752 bytes
Variable Size    629145600 bytes
Database Buffers   125829120 bytes
Redo Buffers      7872512 bytes
Database mounted.
ORA-01113: file 13 needs media recovery
ORA-01110: data file 13: '/u01/app/oracle/oradata/ORCL/users02.dbf'
SQL> set linesize 200
col name form a55 
select a.file#,a.name,a.CHECKPOINT_CHANGE# con_cc,b.CHECKPOINT_CHANGE# data_cc,to_char(a.CHECKPOINT_TIME,'yyyy-mm-dd hh24:mi:ss') CPT from v$datafile a ,v$datafile_header b where a.file#=b.file#;
SQL> SQL> 
     FILE# NAME              CON_CC  DATA_CC CPT
---------- ------------------------------------------------------- ---------- ---------- -------------------
  1 /u01/app/oracle/oradata/ORCL/system01.dbf        2805225  2805225 2021-04-26 17:41:49
  3 /u01/app/oracle/oradata/ORCL/sysaux01.dbf        2805225  2805225 2021-04-26 17:41:49
  4 /u01/app/oracle/oradata/ORCL/undotbs01.dbf        2805225  2805225 2021-04-26 17:41:49
  5 /u01/app/oracle/oradata/ORCL/pdbseed/system01.dbf       1559612  1559612 2018-10-19 11:55:19
  6 /u01/app/oracle/oradata/ORCL/pdbseed/sysaux01.dbf       1559612  1559612 2018-10-19 11:55:19
  7 /u01/app/oracle/oradata/ORCL/users01.dbf        2805225  2805225 2021-04-26 17:41:49
  8 /u01/app/oracle/oradata/ORCL/pdbseed/undotbs01.dbf       1559612  1559612 2018-10-19 11:55:19
  9 /u01/app/oracle/oradata/ORCL/orclpdb/system01.dbf       2583603  2583603 2021-04-26 11:42:12
  10 /u01/app/oracle/oradata/ORCL/orclpdb/sysaux01.dbf       2583603  2583603 2021-04-26 11:42:12
  11 /u01/app/oracle/oradata/ORCL/orclpdb/undotbs01.dbf       2583603  2583603 2021-04-26 11:42:12
  12 /u01/app/oracle/oradata/ORCL/orclpdb/users01.dbf       2583603  2583603 2021-04-26 11:42:12
     FILE# NAME              CON_CC  DATA_CC CPT
---------- ------------------------------------------------------- ---------- ---------- -------------------
  13 /u01/app/oracle/oradata/ORCL/users02.dbf        2805225  2804056 2021-04-26 17:41:49
12 rows selected.


视图vd a t a f i l e 的 内 容 来 自 控 制 文 件 , 视 图 v datafile的内容来自控制文件,视图vdatafile的内容来自控制文件,视图vdatafile_header的内容来自数据文件,连接这两个视图发现第13个数据文件的控制文件的checkpoint和数据文件头的checkpoint不一致。

使用recover database进行恢复

SQL> 
SQL> recover database until cancel;
ORA-00279: change 2804056 generated at 04/26/2021 17:38:20 needed for thread 1
ORA-00289: suggestion : /u01/app/oracle/product/18.0.0/db_1/dbs/arch1_3_1070883714.dbf
ORA-00280: change 2804056 for thread 1 is in sequence #3
Specify log: {<RET>=suggested | filename | AUTO | CANCEL}
/u01/app/oracle/oradata/ORCL/redo03.log
Log applied.
Media recovery complete.
SQL> select * from v$log;
    GROUP#    THREAD#  SEQUENCE#      BYTES  BLOCKSIZE   MEMBERS ARC
---------- ---------- ---------- ---------- ---------- ---------- ---
STATUS   FIRST_CHANGE# FIRST_TIM NEXT_CHANGE# NEXT_TIME     CON_ID
---------------- ------------- --------- ------------ --------- ----------
  1     1        1  209715200    512  1 YES
INACTIVE        2583461 26-APR-21      2685066 26-APR-21   0
  3     1        3  209715200    512  1 NO
CURRENT         2803521 26-APR-21   1.8447E+19    0
  2     1        2  209715200    512  1 YES
INACTIVE        2685066 26-APR-21      2803521 26-APR-21   0


提示需要从SCN 2804056开始恢复,检查vl o g 视 图 , 发 现 这 个 S C N 在 第 3 个 联 机 日 志 里 面 , 输 入 第 3 个 联 机 日 志 文 件 的 文 件 路 径 和 文 件 名 , 恢 复 后 , 检 查 发 现 第 13 个 数 据 文 件 的 S C N 变 成 了 一 致 的 状 态 。 S Q L > s e l e c t n a m e f r o m v log视图,发现这个SCN在第3个联机日志里面,输入第3个联机日志文件的文件路径和文件名,恢复后,检查发现第13个数据文件的SCN变成了一致的状态。 SQL> select name from vlog视图,发现这个SCN在第3个联机日志里面,输入第3个联机日志文件的文件路径和文件名,恢复后,检查发现第13个数据文件的SCN变成了一致的状态。SQL>selectnamefromvfixed_table where name like ‘%ARCHIVE%’;

也可以在V$ARCHIVED_LOG视图中查找包含这个SCN的归档文件。


使用隐含参数_allow_resetlogs_corruption启动数据库

参考:

_allow_resetlogs_corruption tips

 在前面等例子中,如果需要等第三个联机日志找不到了,还可以使用隐含参数_allow_resetlogs_corruption启动数据库。


SQL> ALTER SYSTEM SET "_allow_resetlogs_corruption"= TRUE SCOPE = SPFILE;
System altered.
SQL> startup force;
ORACLE instance started.
Total System Global Area  771747984 bytes
Fixed Size      8900752 bytes
Variable Size    629145600 bytes
Database Buffers   125829120 bytes
Redo Buffers      7872512 bytes
Database mounted.
ORA-01589: must use RESETLOGS or NORESETLOGS option for database open
SQL> alter database open resetlogs;
Database altered.



在数据库日志中有类似下面的提示:

RESETLOGS is being done without consistancy checks. This may result
in a corrupted database. The database should be recreated.
RESETLOGS after incomplete recovery UNTIL CHANGE 2805283 time

验证数据文件13里面的数据结构:


SQL> ANALYZE TABLE user2_t1 VALIDATE STRUCTURE CASCADE;
ANALYZE TABLE user2_t1 VALIDATE STRUCTURE CASCADE
*
ERROR at line 1:
ORA-00600: internal error code, arguments: [kcbzib_6], [0], [4], [], [], [], [], [], [], [], [], []
SQL> select count(*) from user2_t1;
select count(*) from user2_t1
                     *
ERROR at line 1:
ORA-00600: internal error code, arguments: [kcbzib_6], [0], [4], [], [], [], [], [], [], [], [], []


将数据导出,新建数据库再导入。


ALTER SYSTEM SET "_allow_resetlogs_corruption"= false SCOPE = SPFILE;


相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
关系型数据库 Linux BI
数据库的一些知识
数据库的一些知识
43 0
|
2月前
|
存储 数据管理 数据库
数据库三部分
数据库:用于存储数据的地方 数据库管理系统(DataBase Management System,DBMS):用于管理数据库的软件。是用户创建,管理和维护数据库时所使用的软件,位于用户和操作系统之间,对数据库进行统一管理。DBMS能定义数据存储结构,提供数据的操作机制,维护数据库的安全性,完整性和可靠性。 数据库应用程序:为了提高数据库系统的处理能力所使用的的管理数据库的软件补充。大多情况下,DBMS无法满足对数据管理的要求。数据库应用程序的使用可以满足对数据管理的更高要求,还可以使数据管理过程更加直观和友好。数据库应用程序负责与DBMS进行通信,访问和管理DBMS中存
ly~
|
3月前
|
存储 SQL NoSQL
数据库介绍
数据库是组织、存储和管理数据的仓库,分为关系型(RDBMS)和非关系型(NoSQL)。RDBMS 如 MySQL、Oracle 和 SQL Server 通过表间关系存储结构化数据;NoSQL 包括 MongoDB、Redis 和 Neo4j,处理非结构化数据。数据库功能组件有数据定义语言(DDL)、数据操作语言(DML)和数据库管理系统(DBMS)。应用场景涵盖企业资源规划(ERP)、电子商务和大数据分析,支持自动化管理、数据分析及决策支持。
ly~
43 3
|
8月前
|
数据库
数据库(二)
数据查询教程包括单表查询操作,如Select语句用于选取属性,可指定列名、使用别名、计算表达式,并通过Distinct去除重复元组。条件查询(Where子句)支持比较运算,如Between、In、Like(支持模糊匹配)及空值判断。连接查询用于合并多表数据,如内连接、外连接和笛卡尔积。例如,通过连接emp和dept表,可获取员工姓名及其所在部门名称。
50 3
|
8月前
|
关系型数据库 MySQL 数据库
数据库(四)
`DELETE` 语句用于从表中移除数据。基本语法是 `DELETE FROM 表名 WHERE 条件表达式`,条件可选,若省略则删除所有数据。例如,`DELETE FROM emp WHERE dept_id = 10` 删除10号部门员工。`TRUNCATE` 表名更快,用于清空表,但不支持条件,且数据不可恢复。子查询可用于`CREATE TABLE AS SELECT`来复制表,或在`INSERT`, `UPDATE`语句中进行复杂操作,如更新特定区域员工的工资。
41 1
|
8月前
|
数据库
数据库视频(四)
数据库视频(四)
49 0
|
存储 SQL NoSQL
|
8月前
|
存储 SQL 关系型数据库
初识数据库
初识数据库
|
SQL 资源调度 关系型数据库
快速学完数据库
本来想写文章来复习的,后面发现越写越多,而且感觉本末倒置了,查询语句写的最少,其他倒是写的很详细,数据库知识真的太细太碎了,整理起来难度真的挺大的,如果是数据库小白,这篇文章肯定很有用,它没有过多的实战,带你了解数据库的基本框架和能够完成的任务,如果是数据库学过的话,那这篇文章可能对你而言只有前面数据库概述和设计数据库有用,数据库sql语句这部分非常的精简,几乎只是了解个框架,第一次写长文欢迎评论区大佬们的指正。
89 0
快速学完数据库
|
SQL 关系型数据库 Linux
一日一技:这个数据库用起来刚刚好
一日一技:这个数据库用起来刚刚好
157 0