菅舛 发表于 2026-1-10 01:35:04

obet快速修改scn/resetlogs恢复数据库(缺少归档,ORA-00308)

最初是由于业务系统报ORA-01578导致

然后相关人员上来进行了一系列操作,包括但不限于offline文件,create datafile 44,recover datafile,还尝试做resetlogs,使用备份控制文件还原等等.我接手该故障的时候状态

44号文件状态是12月1日的,而且resetlogs信息也不对.通过和客户沟通,确认是他们在没有备份44号文件的前提下直接执行了类似alter database create datafile 44的命令,但是在应用了写归档之后,发现提示有归档不存在 
ALTER DATABASE RECOVER    CONTINUE DEFAULTMedia Recovery Log /data/app/oracle/archive/orcl/1_181285_1103629544.dbfORA-279 signalled during: ALTER DATABASE RECOVER    CONTINUE DEFAULT  ...ALTER DATABASE RECOVER    CONTINUE DEFAULTMedia Recovery Log /data/app/oracle/archive/orcl/1_181286_1103629544.dbfTue Jan 06 12:48:12 2026Errors with log /data/app/oracle/archive/orcl/1_181286_1103629544.dbfErrors in file /data/app/oracle/diag/rdbms/orcl8/orcl/trace/orcl_pr00_8338.trc:ORA-00308: cannot open archived log '/data/app/oracle/archive/orcl/1_181286_1103629544.dbf'ORA-27037: unable to obtain file statusLinux-x86_64 Error: 2: No such file or directoryAdditional information: 3分析现存归档,确实发现12月1日之后丢失了部分归档日志(归档不连续)

基于这种情况(故障数据文件直接被覆盖,归档又出现了多天的连续断档,而且没有有效备份),只能先打开数据库,然后根据情况导出数据,然后导入到新库中.这里我直接使用obet来修改resetlogs和checkpoint 信息,实现数据库快速打开 
OBET> helpOBET (Oracle Block Editor Tool) commands:  open     - Load file list from config file (format:)  info                  - Show loaded file list (from open command)  set filename    - Set target file path (required)  set file         - Set filename using loaded file number (from open list)  set blocksize   - Set block size (2048,4096,,16384,32768)  set block        - Set block number (starts from 0, default: 1)  set offset    - Set offset within block (< blocksize, default: 0)  set count      - Set number of bytes to read (default: 32)  set mode edit/browse  - Enable edit/browse mode  d/dump       - Display data (options: block X, offset Y, count N)  m/modify - Modify data with hex (opts: block X, offset Y)  undo                  - Undo last modification  sum          - Calculate checksum for block (default: current block)  sum apply    - Apply checksum: write calculated value to block  tailchk      - Calculate tailchk for block (default: current block)  tailchk apply - Apply tailchk: write calculated value to block  repair       - Repair bad block (fix seq_kcbh, tailchk, checksum)  copy datato   - Copy data between files     format: file,block,offset,count (e.g., 1,1,10,64)     format: file[,block][,offset] (e.g., 3 or 3,1 or 3,1,128)  copy block file#,block# to file#,block#     - Copy entire data block  copy chkscn file n to file m         - Copy datafile header checkpoint SCN info  copy resetlogscn file n to file m    - Copy datafile header resetlogs info  backup - Backup data block (optional file and block parameters)  corrupt      - Mark block as corrupted (default: current block)  show                  - Display current settings (filename, blocksize, block, offset, count, mode)  license               - Show/manage software license (registration code required)  version               - Show software version and developer information  p/print        - Print Oracle structure,Use the 'p/print' command to see details  undo                  - Undo the last copy chkscn or copy resetlogscn operation  spool           - Start logging to file (spool off to stop)  help                  - Show this help message  quit/exit             - Exit OBET OBET> open 1.txt                 Loaded 2 files from config file '1.txt'. OBET> info Loaded files (2 total):----------------------------------------Number  Path----------------------------------------     1  /data/app/oracle/oradata/orcl/system01.dbf    44  /data/app/oracle/oradata/orcl/xff26.dbf---------------------------------------- OBET> set file 44filename set to: /data/app/oracle/oradata/orcl/xff26.dbf (file#44) OBET> d File: /data/app/oracle/oradata/orcl/xff26.dbfBlock: 1                Offsets:     0 to    31--------------------------------------------------------------------------------0xifenfei000 0BA20000 0100000B 00000000 00000104 B05F0000 00000000 0004200B 65583D61    OBET> backup file 44 block 1Created backup directory: backup_blkSuccessfully backed up block 1 from file#44 to /tmp/backup_blk/xff26.dbf_1.20260106182405 OBET> copy resetlogscn file 1 to file 44Error: Edit mode not enabled. Use 'set mode edit' first. OBET> set mode edit     mode set to: edit OBET> copy resetlogscn file 1 to file 44 Confirm Modify resetlogscn:Source: file#1 (/data/app/oracle/oradata/orcl/system01.dbf)Target: file#44 (/data/app/oracle/oradata/orcl/xff26.dbf)Proceed? (Y/YES to confirm): ySuccessfully copied resetlog SCN information from file#1 to file#44. OBET> copy chkscn file 1 to file 44 Confirm Modify chkscn:Source: file#1 (/data/app/oracle/oradata/orcl/system01.dbf)Target: file#44 (/data/app/oracle/oradata/orcl/xff26.dbf)Proceed? (Y/YES to confirm): ySuccessfully copied checkpoint SCN information from file#1 to file#44. OBET> tailchkCheck tailchk for File /data/app/oracle/oradata/orcl/xff26.dbf, Block 1:current = 0x010B0000, required = 0x010B0000 OBET> sumCheck value for File /data/app/oracle/oradata/orcl/xff26.dbf, Block 1:current = 0xB05F, required = 0x6DA3 OBET> sum apply Confirm applying checksum:File: /data/app/oracle/oradata/orcl/xff26.dbfBlock: 1Offset in block: 16 (file offset: 0x0xifenfei010)Original value: 0xB05FNew value:      0x6DA3Confirm? (Y/YES to proceed): yVerification successful: Stored checksum matches calculated value (0x6DA3).Checksum applied successfully.然后重建ctl正常打开数据库
$ sqlplus / as sysdba SQL*Plus: Release 11.2.0.4.0 Production on Tue Jan 6 18:29:22 2026 Copyright (c) 1982, 2013, Oracle.  All rights reserved. Connected to an idle instance. SQL> startup mount pfile='/tmp/pfile';ORACLE instance started. Total System Global Area 6.8413E+10 bytesFixed Size          2270360 bytesVariable Size        3.3554E+10 bytesDatabase Buffers     3.4762E+10 bytesRedo Buffers           93585408 bytesDatabase mounted.SQL> alter database open;alter database open*ERROR at line 1:ORA-01190: control file or data file 1 is from before the last RESETLOGSORA-01110: data file 1: '/data/app/oracle/oradata/orcl/system01.dbf'  SQL> shutdown immediate;ORA-01109: database not open  Database dismounted.ORACLE instance shut down.SQL> SQL> SQL> startup nomount pfile='/tmp/pfile';ORACLE instance started. Total System Global Area 6.8413E+10 bytesFixed Size          2270360 bytesVariable Size        3.3554E+10 bytesDatabase Buffers     3.4762E+10 bytesRedo Buffers           93585408 bytesSQL> @ctl.sql Control file created. SQL> SQL> recover database;ORA-00283: recovery session canceled due to errorsORA-00264: no recovery required  SQL> alter database open; Database altered.后续根据情况选择导出表,对于导出报错的表再进行二次处理.

来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

捐催制 发表于 2026-1-13 06:46:33

感谢分享

铵滔 发表于 2026-1-20 05:19:35

不错,里面软件多更新就更好了

院儿饯 发表于 2026-1-21 07:56:09

感谢发布原创作品,程序园因你更精彩

驶桐柢 发表于 2026-1-21 14:36:01

鼓励转贴优秀软件安全工具和文档!

陈兰芳 发表于 2026-1-21 23:18:52

用心讨论,共获提升!

颐港 发表于 2026-1-27 04:03:42

感谢发布原创作品,程序园因你更精彩

迫蔺 发表于 2026-2-1 03:40:27

不错,里面软件多更新就更好了

桂册 发表于 2026-2-6 04:48:14

这个好,看起来很实用

冷晓晴 发表于 2026-2-7 23:26:44

东西不错很实用谢谢分享

贼瘁 发表于 2026-2-7 23:56:12

感谢分享,下载保存了,貌似很强大

挚魉 发表于 2026-2-9 01:04:03

东西不错很实用谢谢分享

普料飕 发表于 2026-2-9 13:45:09

这个有用。

坠矜 发表于 2026-2-11 10:56:52

感谢发布原创作品,程序园因你更精彩

姊囝 发表于 2026-2-11 14:59:47

收藏一下   不知道什么时候能用到

浦乐 发表于 2026-2-12 04:41:26

感谢分享

陈兰芳 发表于 2026-2-12 15:03:12

东西不错很实用谢谢分享

丰江 发表于 2026-2-18 13:26:59

用心讨论,共获提升!

晾棋砷 发表于 2026-2-28 06:39:42

热心回复!

山芷兰 发表于 2026-3-7 08:39:00

yyds。多谢分享
页: [1] 2
查看完整版本: obet快速修改scn/resetlogs恢复数据库(缺少归档,ORA-00308)