标签云
asm恢复 bbed bootstrap$ dul In Memory kcbzib_kcrsds_1 kccpb_sanity_check_2 kfed MySQL恢复 ORA-00312 ORA-00607 ORA-00704 ORA-01110 ORA-01555 ORA-01578 ORA-08103 ORA-600 2131 ORA-600 2662 ORA-600 2663 ORA-600 3020 ORA-600 4000 ORA-600 4137 ORA-600 4193 ORA-600 4194 ORA-600 16703 ORA-600 kcbzib_kcrsds_1 ORA-600 KCLCHKBLK_4 ORA-15042 ORA-15196 ORACLE 12C oracle dul ORACLE PATCH Oracle Recovery Tools oracle加密恢复 oracle勒索 oracle勒索恢复 oracle异常恢复 Oracle 恢复 ORACLE恢复 ORACLE数据库恢复 oracle 比特币 OSD-04016 YOUR FILES ARE ENCRYPTED 勒索恢复 比特币加密文章分类
- Others (2)
- 中间件 (2)
- WebLogic (2)
- 操作系统 (102)
- 数据库 (1,683)
- DB2 (22)
- MySQL (73)
- Oracle (1,545)
- Data Guard (52)
- EXADATA (8)
- GoldenGate (24)
- ORA-xxxxx (159)
- ORACLE 12C (72)
- ORACLE 18C (6)
- ORACLE 19C (15)
- ORACLE 21C (3)
- Oracle 23ai (7)
- Oracle ASM (68)
- Oracle Bug (8)
- Oracle RAC (53)
- Oracle 安全 (6)
- Oracle 开发 (28)
- Oracle 监听 (28)
- Oracle备份恢复 (565)
- Oracle安装升级 (92)
- Oracle性能优化 (62)
- 专题索引 (5)
- 勒索恢复 (79)
- PostgreSQL (18)
- PostgreSQL恢复 (6)
- SQL Server (27)
- SQL Server恢复 (8)
- TimesTen (7)
- 达梦数据库 (2)
- 生活娱乐 (2)
- 至理名言 (11)
- 虚拟化 (2)
- VMware (2)
- 软件开发 (37)
- Asp.Net (9)
- JavaScript (12)
- PHP (2)
- 小工具 (20)
-
最近发表
- ORA-15411: Failure groups in disk group DATA have different number of disks.
- 断电引起的ORA-08102: 未找到索引关键字, 对象号 39故障处理
- ORA-00227: corrupt block detected in control file
- 手工删除19c rac
- 解决oracle数据文件路径有回车故障
- .wstop扩展名勒索数据库恢复
- Oracle Recovery Tools工具一键解决ORA-00376 ORA-01110故障(文件offline)
- OGG-02771 Input trail file format RELEASE 19.1 is different from previous trail file form at RELEASE 11.2.
- OGG-02246 Source redo compatibility level 19.0.0 requires trail FORMAT 12.2 or higher
- GoldenGate 19安装和打patch
- dd破坏asm磁盘头恢复
- 删除asmlib磁盘导致磁盘组故障恢复
- Kylin Linux 安装19c
- ORA-600 krse_arc_complete.4
- Oracle 19c 202410补丁(RUs+OJVM)
- ntfs MFT损坏(ntfs文件系统故障)导致oracle异常恢复
- .mkp扩展名oracle数据文件加密恢复
- 清空redo,导致ORA-27048: skgfifi: file header information is invalid
- A_H_README_TO_RECOVER勒索恢复
- 通过alert日志分析客户自行对一个数据库恢复的来龙去脉和点评
标签归档:asm拷贝block
dbms_diskgroup拷贝block/datafile
对于asm而言,如果我们要操作里面的数据文件,虽然从11.2开始有asmcmd的cp可能进行拷贝,但是如果想对数据文件中的某个block进行拷贝出来asm到文件系统(或者拷贝某个文件系统的block到asm中),还是比较麻烦的事情(请见:bbed修改ASM中数据)。其实oracle官方提供了dbms_diskgroup这个包,可以通过sqlplus直接操作asm里面的block/datafile,非常方便,这里简单列举几个例子:
dbms_diskgroup获取asm中文件属性
SQL> declare 2 v_filename varchar2(4000); 3 v_filetype number; 4 v_filesize number; 5 v_lbks number; 6 v_typename varchar2(4000); 7 begin 8 dbms_output.enable(5000); 9 v_filename := '&file_name'; 10 dbms_diskgroup.getfileattr(v_filename,v_filetype,v_filesize,v_lbks); 11 select decode(v_filetype,1,'Control File',2,'Data File',3,'Online Log File',4,'Archive Log',5,'Trace File',6,'Temporary File', 12 7,'Not Used',8,'Not Used',9,'Backup Piece',10,'Incremental Backup Piece',11,'Archive Backup Piece',12,'Data File Copy', 13 13,'Spfile',14,'Disaster Recovery Configuration',15,'Storage Manager Disk',16,'Change Tracking File',17,'Flashback Log File', 14 18,'DataPump Dump File',19,'Cross Platform Converted File',20,'Autobackup',21,'Any OS file',22,'Block Dump File', 15 23,'CSS Voting File',24,'CRS') into v_typename from dual; 16 dbms_output.put_line('File: '||v_filename); dbms_output.new_line; 17 dbms_output.put_line('Type: '||v_filetype||' '||v_typename); dbms_output.new_line; 18 dbms_output.put_line('Size (Logical Block Size): '||v_filesize); dbms_output.new_line; 19 dbms_output.put_line('Logical Block Size: '||v_lbks); dbms_output.new_line; 20 end; 21 / Enter value for file_name: +DATA/xifenfei/datafile/system.256.878224279 old 9: v_filename := '&file_name'; new 9: v_filename := '+DATA/xifenfei/datafile/system.256.878224279'; File: +DATA/xifenfei/datafile/system.256.878224279 Type: 12 Data File Copy Size (Logical Block Size): 94720 Logical Block Size: 8192 PL/SQL procedure successfully completed.
创建测试表t_xifenfei
SQL> create table t_xifenfei tablespace users 2 as select 'www.xifenfei.com' xifenfei from dual; Table created. SQL> select rowid,xifenfei from t_xifenfei; ROWID XIFENFEI ------------------ ---------------- AAAVU3AAEAAAACrAAA www.xifenfei.com SQL> select 2 dbms_rowid.rowid_relative_fno(rowid) rel_fno, 3 dbms_rowid.rowid_block_number(rowid )block_no 4 from t_xifenfei; REL_FNO BLOCK_NO ---------- ---------- 4 171 SQL> alter system checkpoint; System altered. SQL> / System altered. SQL> alter system switch logfile; System altered. SQL> select name from v$datafile where file#=4; NAME -------------------------------------------------------------------------------- +DATA/xifenfei/datafile/users.259.878224279
dbms_diskgroup拷贝asm datafile 4 block 171
SQL> declare 2 v_AsmFilename varchar2(4000); 3 v_FsFilename varchar2(4000); 4 v_offstart number; 5 v_numblks number; 6 v_filetype number; 7 v_filesize number; 8 v_lbks number; 9 v_typename varchar2(4000); 10 v_pblksize number; 11 v_handle number; 12 begin 13 dbms_output.enable(500000); 14 v_AsmFilename := '&ASM_File_Name'; 15 v_offstart := '&block_to_extract'; 16 v_numblks := '&number_of_blocks_to_extract'; 17 v_FsFilename := '&FileSystem_File_Name'; 18 dbms_diskgroup.getfileattr(v_AsmFilename,v_filetype,v_filesize,v_lbks); 19 dbms_diskgroup.open(v_AsmFilename,'r',v_filetype,v_lbks,v_handle,v_pblksize,v_filesize); 20 dbms_diskgroup.close(v_handle); 21 select decode(v_filetype,1,'Control File',2,'Data File',3,'Online Log File',4,'Archive Log',5,'Trace File',6,'Temporary File', 22 7,'Not Used',8,'Not Used',9,'Backup Piece',10,'Incremental Backup Piece',11,'Archive Backup Piece',12,'Data File Copy', 23 13,'Spfile',14,'Disaster Recovery Configuration',15,'Storage Manager Disk',16,'Change Tracking File',17,'Flashback Log File', 24 18,'DataPump Dump File',19,'Cross Platform Converted File',20,'Autobackup',21,'Any OS file',22,'Block Dump File', 25 23,'CSS Voting File',24,'CRS') into v_typename from dual; 26 dbms_output.put_line('File: '||v_AsmFilename); dbms_output.new_line; 27 dbms_output.put_line('Type: '||v_filetype||' '||v_typename); dbms_output.new_line; 28 dbms_output.put_line('Size (in logical blocks): '||v_filesize); dbms_output.new_line; 29 dbms_output.put_line('Logical Block Size: '||v_lbks); dbms_output.new_line; 30 dbms_output.put_line('Physical Block Size: '||v_pblksize); dbms_output.new_line; 31 dbms_diskgroup.patchfile(v_AsmFilename,v_filetype,v_lbks,v_offstart,0,v_numblks,v_FsFilename,v_filetype,1,1); 32 end; 33 / Enter value for asm_file_name: +DATA/xifenfei/datafile/users.259.878224279 old 14: v_AsmFilename := '&ASM_File_Name'; new 14: v_AsmFilename := '+DATA/xifenfei/datafile/users.259.878224279'; Enter value for block_to_extract: 171 old 15: v_offstart := '&block_to_extract'; new 15: v_offstart := '171'; Enter value for number_of_blocks_to_extract: 1 old 16: v_numblks := '&number_of_blocks_to_extract'; new 16: v_numblks := '1'; Enter value for filesystem_file_name: /tmp/xifenfei.dbf old 17: v_FsFilename := '&FileSystem_File_Name'; new 17: v_FsFilename := '/tmp/xifenfei.dbf'; File: +DATA/xifenfei/datafile/users.259.878224279 Type: 12 Data File Copy Size (in logical blocks): 640 Logical Block Size: 8192 Physical Block Size: 512 PL/SQL procedure successfully completed. [grid@xifenfei ~]$ ls -l /tmp/xifenfei.dbf -rw-r----- 1 grid oinstall 16384 Apr 28 15:55 /tmp/xifenfei.dbf
这里注意拷贝出来的block size 为8192,由于默认写了block 0信息,因此这里显示大小为2*block size=16384
bbed修改拷贝出来block内容
SQL> select dump('xifenfei',16) from dual; DUMP('XIFENFEI',16) ------------------------------------- Typ=96 Len=8: 78,69,66,65,6e,66,65,69 SQL> select dump('XIFENFEI',16) from dual; DUMP('XIFENFEI',16) ------------------------------------- Typ=96 Len=8: 58,49,46,45,4e,46,45,49 [oracle@xifenfei tmp]$ bbed filename='/tmp/xifenfei.dbf' blocksize=8192 Password: BBED: Release 2.0.0.0.0 - Limited Production on Tue Apr 28 16:24:35 2015 Copyright (c) 1982, 2011, Oracle and/or its affiliates. All rights reserved. ************* !!! For Oracle Internal Use only !!! *************** BBED> show FILE# 0 BLOCK# 1 OFFSET 0 DBA 0x00000000 (0 0,1) FILENAME /tmp/xifenfei.dbf BIFILE bifile.bbd LISTFILE BLOCKSIZE 8192 MODE Browse EDIT Unrecoverable IBASE Dec OBASE Dec WIDTH 80 COUNT 512 LOGFILE log.bbd SPOOL No BBED> map File: /tmp/xifenfei.dbf (0) Block: 1 Dba:0x00000000 ------------------------------------------------------------ KTB Data Block (Table/Cluster) struct kcbh, 20 bytes @0 struct ktbbh, 96 bytes @20 struct kdbh, 14 bytes @124 struct kdbt[1], 4 bytes @138 sb2 kdbr[1] @142 ub1 freespace[8024] @144 ub1 rowdata[20] @8168 ub4 tailchk @8188 BBED> p *kdbr[0] rowdata[0] ---------- ub1 rowdata[0] @8168 0x2c BBED> d /v offset 8168 File: /tmp/xifenfei.dbf (0) Block: 1 Offsets: 8168 to 8191 Dba:0x00000000 ------------------------------------------------------- 2c000110 7777772e 78696665 6e666569 l ,...www.xifenfei 2e636f6d 020624bc l .com..$. <16 bytes per line> BBED> r /x c BBED-00200: invalid keyword (r) BBED> x /rc rowdata[0] @8168 ---------- flag@8168: 0x2c (KDRHFL, KDRHFF, KDRHFH) lock@8169: 0x00 cols@8170: 1 col 0[16] @8171: www.xifenfei.com BBED> set mode edit MODE Edit BBED> set offset 8171 OFFSET 8171 BBED> set count 32 COUNT 32 BBED> d File: /tmp/xifenfei.dbf (0) Block: 1 Offsets: 8171 to 8191 Dba:0x00000000 ------------------------------------------------------------------------ 10777777 2e786966 656e6665 692e636f 6d020624 bc <32 bytes per line> BBED> BBED> set offset +5 OFFSET 8176 BBED> d File: /tmp/xifenfei.dbf (0) Block: 1 Offsets: 8176 to 8191 Dba:0x00000000 ------------------------------------------------------------------------ 78696665 6e666569 2e636f6d 020624bc <32 bytes per line> BBED> m /x 58494645 File: /tmp/xifenfei.dbf (0) Block: 1 Offsets: 8176 to 8191 Dba:0x00000000 ------------------------------------------------------------------------ 58494645 6e666569 2e636f6d 020624bc <32 bytes per line> BBED> set offset +4 OFFSET 8180 BBED> d File: /tmp/xifenfei.dbf (0) Block: 1 Offsets: 8180 to 8191 Dba:0x00000000 ------------------------------------------------------------------------ 6e666569 2e636f6d 020624bc <32 bytes per line> BBED> m /x 4e464549 File: /tmp/xifenfei.dbf (0) Block: 1 Offsets: 8180 to 8191 Dba:0x00000000 ------------------------------------------------------------------------ 4e464549 2e636f6d 020624bc <32 bytes per line> BBED> d /v offset 8168 File: /tmp/xifenfei.dbf (0) Block: 1 Offsets: 8168 to 8191 Dba:0x00000000 ------------------------------------------------------- 2c000110 7777772e 58494645 4e464549 l ,...www.XIFENFEI 2e636f6d 020624bc l .com..$. <16 bytes per line> BBED> x /rc rowdata[0] @8168 ---------- flag@8168: 0x2c (KDRHFL, KDRHFF, KDRHFH) lock@8169: 0x00 cols@8170: 1 col 0[16] @8171: www.XIFENFEI.com BBED> sum apply Check value for File 0, Block 1: current = 0x3060, required = 0x3060
这里通过bbed把拷贝出来的datafile 4 block 171中的www.xifenfei.com修改为www.XIFENFEI.com
dbms_diskgroup拷贝os block to asm datafile 4 block 171
SQL> declare 2 v_FsFileName varchar2(4000); 3 v_AsmFileName varchar2(4000); 4 v_FsFileType number; 5 v_AsmFileType number; 6 v_offstart number; 7 v_filesize number; 8 v_lbks number; 9 v_typename varchar2(4000); 10 v_handle number; 11 error number; 12 txt varchar2(4000); 13 begin 14 dbms_output.enable(500000); 15 v_FsFileName := '&file_with_patched_block'; 16 v_AsmFileName := '&file_to_patch_in_ASM'; 17 v_offstart := '&block_to_patch'; 18 dbms_diskgroup.getfileattr(v_AsmFileName,v_AsmFileType,v_filesize,v_lbks); 19 select decode(v_AsmFileType,1,'Control File',2,'Data File',3,'Online Log File',4,'Archive Log',5,'Trace File',6,'Temporary File', 20 7,'Not Used',8,'Not Used',9,'Backup Piece',10,'Incremental Backup Piece',11,'Archive Backup Piece',12,'Data File Copy', 21 13,'Spfile',14,'Disaster Recovery Configuration',15,'Storage Manager Disk',16,'Change Tracking File', 22 17,'Flashback Log File', 23 18,'DataPump Dump File',19,'Cross Platform Converted File',20,'Autobackup',21,'Any OS file',22,'Block Dump File', 24 23,'CSS Voting File',24,'CRS') into v_typename from dual; 25 dbms_output.put_line('File: '||v_AsmFileName); dbms_output.new_line; 26 dbms_output.put_line('Type: '||v_AsmFileType||' '||v_typename); dbms_output.new_line; 27 dbms_output.put_line('Size: '||v_filesize); dbms_output.new_line; 28 dbms_output.put_line('Logical Block Size: '||v_lbks); dbms_output.new_line; 29 dbms_diskgroup.patchfile(v_FsFileName,12,v_lbks,1,0,1,v_AsmFileName,v_AsmFileType,v_offstart,0); 30 end; 31 / Enter value for file_with_patched_block: /tmp/xifenfei.dbf old 15: v_FsFileName := '&file_with_patched_block'; new 15: v_FsFileName := '/tmp/xifenfei.dbf'; Enter value for file_to_patch_in_asm: +DATA/xifenfei/datafile/users.259.878224279 old 16: v_AsmFileName := '&file_to_patch_in_ASM'; new 16: v_AsmFileName := '+DATA/xifenfei/datafile/users.259.878224279'; Enter value for block_to_patch: 171 old 17: v_offstart := '&block_to_patch'; new 17: v_offstart := '171'; File: +DATA/xifenfei/datafile/users.259.878224279 Type: 12 Data File Copy Size: 640 Logical Block Size: 8192 PL/SQL procedure successfully completed.
验证修改block是否正确
SQL> shutdown abort ORACLE instance shut down. SQL> startup ORACLE instance started. Total System Global Area 952020992 bytes Fixed Size 2258960 bytes Variable Size 306186224 bytes Database Buffers 637534208 bytes Redo Buffers 6041600 bytes Database mounted. Database opened. SQL> select rowid,xifenfei from t_xifenfei; ROWID XIFENFEI ------------------ ---------------- AAAVU3AAEAAAACrAAA www.XIFENFEI.com
dbms_diskgroup拷贝asm datafile to os
SQL> declare 2 v_AsmFileName varchar2(4000); 3 v_FsFileName varchar2(4000); 4 v_filetype number; 5 v_filesize number; 6 v_lbks number; 7 v_typename varchar2(4000); 8 v_pblksize number; 9 v_handle number; 10 begin 11 dbms_output.enable(500000); 12 v_AsmFileName := '&ASM_file_name'; 13 v_FsFileName := '&FileSystem_file_name'; 14 dbms_diskgroup.getfileattr(v_AsmFileName,v_filetype,v_filesize,v_lbks); 15 dbms_diskgroup.open(v_AsmFileName,'r',v_filetype,v_lbks,v_handle,v_pblksize,v_filesize); 16 dbms_diskgroup.close(v_handle); 17 select decode(v_filetype,1,'Control File',2,'Data File',3,'Online Log File',4,'Archive Log',5,'Trace File',6,'Temporary File', 18 7,'Not Used',8,'Not Used',9,'Backup Piece',10,'Incremental Backup Piece',11,'Archive Backup Piece',12,'Data File Copy', 19 13,'Spfile',14,'Disaster Recovery Configuration',15,'Storage Manager Disk',16,'Change Tracking File',17,'Flashback Log File', 20 18,'DataPump Dump File',19,'Cross Platform Converted File',20,'Autobackup',21,'Any OS file',22,'Block Dump File', 21 23,'CSS Voting File',24,'CRS') into v_typename from dual; 22 dbms_output.put_line('File: '||v_AsmFileName); dbms_output.new_line; 23 dbms_output.put_line('Type: '||v_filetype||' '||v_typename); dbms_output.new_line; 24 dbms_output.put_line('Size (in logical blocks): '||v_filesize); dbms_output.new_line; 25 dbms_output.put_line('Logical Block Size: '||v_lbks); dbms_output.new_line; 26 dbms_output.put_line('Physical Block Size: '||v_pblksize); dbms_output.new_line; 27 dbms_diskgroup.patchfile(v_AsmFileName,v_filetype,v_lbks,1,0,v_filesize,v_FsFileName,2,1,1); 28 end; 29 / Enter value for asm_file_name: +DATA/xifenfei/datafile/users.259.878224279 old 12: v_AsmFileName := '&ASM_file_name'; new 12: v_AsmFileName := '+DATA/xifenfei/datafile/users.259.878224279'; Enter value for filesystem_file_name: /tmp/users01.dbf old 13: v_FsFileName := '&FileSystem_file_name'; new 13: v_FsFileName := '/tmp/users01.dbf'; File: +DATA/xifenfei/datafile/users.259.878224279 Type: 12 Data File Copy Size (in logical blocks): 640 Logical Block Size: 8192 Physical Block Size: 512 PL/SQL procedure successfully completed. [grid@xifenfei ~]$ ls -l /tmp/users01.dbf -rw-r----- 1 grid oinstall 5251072 Apr 28 16:39 /tmp/users01.dbf
通过上述几个简单例子说明:dbms_diskgroup可以看asm file的属性,可以拷贝asm中的datafile中的某个block到os,也可以从os拷贝到asm,可以从asm中直接拷贝文件文件到os等功能