深入了解PRM/DUL (PanassusData Recovery Manager) For Oracle Database

PRM 是开放的Oracle灾难恢复软件,任何人均可以下载并传播。
 
 

一个标准的绿色JAVA工具软件

 
PRM(PanassusData Recovery Manager) 是基于标准JAVA语言开发的Oracle数据库灾难恢复软件,可以直接从Oracle数据文件中抽取表的完整数据行,而完全无需通过Oracle数据库软件。 由于PRM绕过了UNDO,所以其读取的数据中少量可能是事务中的数据。同时PRM不要求数据文件已经恢复到了一致性的状态。
 
 

Oracle数据库损坏仍可以拯救出数据的工具

数据库可能部分损坏了,但大多数数据块仍是完好的。在数据拯救过程中,PRM会最大程度从数据块中可用的部分把行数据读取出来,如果确认遇到损坏非常严重的数据块,PRM则会将问题数据块的信息打印到日志中去。

 

可以抽取TABLE/CLUSTER中的数据

PRM主要抽取TABLE/CLUSTER中的数据。PRM从设计角度不是用来抽取如触发器、存储过程或者视图这些对象。 当然由于PRM能够拯救SOURCE$基表的数据,所以变相地可以恢复上述这些对象了。 PRM不恢复索引数据,因为仅仅恢复索引数据一般是没有意义的,除非是IOT索引组织表。

 

独创的DataBridge技术

 

 
为什么要引入数据搭桥模式呢?
 
  • 普通的unload+sqlldr恢复方式意味着要保存一份源数据,一份抽取数据,和一份目标数据,即在恢复过程中可能需要扩容2倍于原来的存储空间,这对于甚至无法腾出备份空间的企业来说十分困难
  • 数据搭桥与普通unload+sqlldr模式的最大区别在于,数据搭桥直接从源库中抽取数据并传送到目标数据库中,无需在文件系统上保留一份抽取数据
  • 通过数据搭桥传送到目标数据库中的数据本身就是结构化的,可以立即使用SQL语句来验证其完整性和一致性
  • 如果数据搭桥的目标数据库库位于异机上,那么源数据库上仅仅做读取操作,读写IO将分布于2台服务器上,PRM恢复的速度将更快
  • 如果用户所需要恢复的是Truncate数据的话,那么可以马上搭桥回到源库中,恢复仅仅是鼠标点几下的工作
 

 

完备的多语言支持

 

PRM在开发过程中充分考虑了多语言支持的问题,利用JAVA语言的全球化特性,PRM几乎支持所有主流的Oracle数据库字符集,以下为PRM支持的语言和字符集CharacterSet列表:

 

 

语言

字符集

对应的编码

中文 简体/繁体

ZHS16GBK

GBK

中文 简体/繁体

ZHS16DBCS

CP935

中文 简体/繁体

ZHT16BIG5

BIG5

中文 简体/繁体

ZHT16DBCS

CP937

中文 简体/繁体

ZHT16HKSCS

CP950

中文 简体/繁体

ZHS16CGB231280

GB2312

中文 简体/繁体

ZHS32GB18030

GB18030

日文

JA16SJIS

SJIS

日文

JA16EUC

EUC_JP

日文

JA16DBCS

CP939

韩语

KO16MSWIN949

MS649

韩语

KO16KSC5601

EUC_KR

韩语

KO16DBCS

CP933

法语

WE8MSWIN1252

CP1252

法语

WE8ISO8859P15

ISO8859_15

法语

WE8PC850

CP850

法语

WE8EBCDIC1148

CP1148

法语

WE8ISO8859P1

ISO8859_1

法语

WE8PC863

CP863

法语

WE8EBCDIC1047

CP1047

法语

WE8EBCDIC1147

CP1147

德语

WE8MSWIN1252

CP1252

德语

WE8ISO8859P15

ISO8859_15

德语

WE8PC850

CP850

德语

WE8EBCDIC1141

CP1141

德语

WE8ISO8859P1

ISO8859_1

德语

WE8EBCDIC1148

CP1148

意大利语

WE8MSWIN1252

CP1252

意大利语

WE8ISO8859P15

ISO8859_15

意大利语

WE8PC850

CP850

意大利语

WE8EBCDIC1144

CP1144

泰语

TH8TISASCII

CP874

泰语

TH8TISEBCDIC

TIS620

阿拉伯语

AR8MSWIN1256

CP1256

阿拉伯语

AR8ISO8859P6

ISO8859_6

阿拉伯语

AR8ADOS720

CP864

西班牙语

WE8MSWIN1252

CP1252

西班牙语

WE8ISO8859P1

ISO8859_1

西班牙语

WE8PC850

CP850

西班牙语

WE8EBCDIC1047

CP1047

葡萄牙语

WE8MSWIN1252

CP1252

葡萄牙语

WE8ISO8859P1

ISO8859_1

葡萄牙语

WE8PC850

CP850

葡萄牙语

WE8EBCDIC1047

CP1047

葡萄牙语

WE8ISO8859P15

ISO8859_15

葡萄牙语

WE8PC860

CP860

 

 

 

 


PRM-DUL Oracle数据库恢复工具,一款专为Oracle数据救援而研发的企业级工具。可在多个操作平台(AIX/HPUX/SOLARIS/Linux/Windows)使用并支持对Oracle 9i/10g/11g/12c各版本数据库的数据救援工作。软件基于JAVA 开发,绿色无需安装,图形化操作界面,易于上手使用。可基于单数据文件操作或Oracle ASM存储磁盘操作。 PRM-DUL Oracle数据库恢复工具(简称PRM-DUL)是一款专为Oracle数据救援而研发的企业级工具。从1.0版本发布到现在,已经历了多次功能增强、补丁修正和恢复逻辑改进。PRM-DUL Oracle数据库恢复工具已在多个操作平台(AIX/HPUX/SOLARIS/Linux/Windows)被证明稳定可用。当前版本软件支持对Oracle 9i/10g/11g/12c各版本数据库的数据救援工作。软件基于JAVA 开发,绿色无需安装,下载解压后便可直接使用。(Windows上直接点击prm.bat,在Linux/Unix上运行./prm.sh)注意JAVA版本推荐在1.6版本以上。如果需对裸设备文件进行数据救援,请安装并使用JAVA openjdk版本,除此之外,使用官方JAVA版本既可。图形化操作界面,易于上手使用。使用者无需额外学习一套命令,或者了解ORACLE 的底层数据结构原理即可以通过恢复向导(Recovery Wizard)来恢复数据库中的数据。软件支持对单个数据文件的数据扫描和抽取,同时也支持对Oracle ASM存储数据恢复。其导出的数据既可导出为sqlldr导入数据文件,也可通过PRM-DUL的Data Bridge功能直接导出并插入到指定新库中,实现不落地恢复。 PRM-DUL Oracle数据库恢复工具功能 》》可以在不需要运行Oracle数据库的情况下直接针对数据库文件或进行数据解析。 》》支持ASM,可直接读取ASM磁盘并对其中数据文件以及文件中的数据进行扫描解析。 》》支持裸设备数据文件读取。 》》支持LOB字段(CLOB, NCLOB和BLOB)恢复,并支持同一个表中,不同LOB列使用不同CHUNK SIZE的情况 》》支持多种Big Endian/Little Endian操作平台(AIX/HPUX/SOLARIS/Linux/Windows)数据库数据恢复 》》支持分区、子分区数据恢复 》》支持各种表,包括普通的HEAP表和聚簇(CLUSTER)表数据恢复 》》支持表被truncate后的数据恢复 》》支持表被drop后的数据恢复 》》支持在没有SYSTEM表空间和数据字典损坏的情况下的非字典模式数据恢复,并能为判断数据类型提供辅助依据 》》支持10g及以上的大文件(BigFile)表空间 》》支持同一个库中不同块大小的数据文件 》》以纯文本导出时,能够自动生成建表的SQL语句和SQL*Loader导入所需的control文件 PRM-DUL Oracle(数据库恢复工具) v4.1更新日志 1. 对使用DELETE命令误删除的数据的救援恢复支持 2. 对在字典模式下LOB数据Data Bridge功能增强,大幅度改善导出性能 3. 增加在非字典模式下LOB数据的Data Bridge支持。 4. 增加对字典模式/非字典模式数据加载信息的重用支持 5. 增加Schema级的DDL导出支持(包含相表,索引,视图建立语句信息) PRM-DUL Oracle数据库恢复工具截图
PRM DUL for oracle恢复被truncate截断掉的表 Oracle DBA神器:PRM灾难恢复工具,Schema级别数据恢复。PRM For Oracle Database – schema级别oracle数据库数据恢复特性 ,PRM即ParnassusData Recovery Manager是企业级别Oracle数据库灾难恢复工具。PRM可以在无备份的情况下恢复被truncated/drop掉的表,也可以恢复无法打开的Oracle数据库(Alter Database Open失败)中的数据。 PRM是图形化增强版的Oracle DUL工具,同时具备很多Oracle DUL不具备的特性 情况 当某张表被意外truncated掉了,需要恢复其上的所有数据时。表空间的多个数据文件均存放在ASM上,且没有任何形式的备份。 注意这边文章针对的是PRM在 数据字典模式下的Truncate恢复选项不可用时使用,数据字典模式下的Truncate恢复选项是最简单、易用的一种模式,具体使用见《使用PRM恢复Oracle数据库中误truncate截断的表数据》http://www.parnassusdata.com/zh-hans/node/52 PRM 3.0的下载地址: http://parnassusdata.com/sites/default/files/ParnassusData_PRMForOracle_3002.zip PRM 的官方网站: http://www.parnassusdata.com/ PRM背景 PRM恢复表数据时存在多种模式, PRM需要知道哪些表上的数据块是需要被读取并取出数据的。默认的表现形式是直接从segment header数据段头里获取EXTENT MAP即盘区图,另一种方案就是由PRM自己去构建一个盘区图。 这些盘区图可以通过,PRM的SCAN DATABASE选项来获得: Recovery Wizard => Non-Dictionary Mode,如果是ASM则选择Non-Dictionary Mode(ASM) 执行SCAN Database后会生成SEG$和EXT$的数据到PRM内嵌的数据库中,之后可以选择SCAN TABLES FROM SEGMENTS 或者 SCAN TABLES FROM EXTENTS。 FROM Segments 意味着使用Segment Header中获得的Extent MAP信息,而FROM Extents意味着使用PRM自己扫描获得的EXTENT信息。 请注意当TRUNCATE发生后, 数据表Table的Segment Header中的Extent MAP信息就会被清空了, 但实际存放数据的数据块中的行数据还是在哪里的,除非被其他数据表/索引的增长而覆盖了。 所以当Truncate发生后选择SCAN TABLES FROM SEGMENT 是找不回数据的,必须使用SCAN TABLES FROM EXTENTS, EXTENT的信息是PRM自己去数据文件中扫描获得的,所以只要有数据的地方PRM就会自己去找到。 除了Truncate需要使用到 SCAN TABLES FROM EXTENTS之外对于DROP TABLE的恢复也可以用到SCAN TABLES FROM EXTENTS , 总之当Segment Header找不到(可能存放Segment Header的数据文件丢失了)、或者已损坏(可能Segment Header的数据块被损坏了)、或者其中的Extent Map数据无效(Truncate、DROP或逻辑损坏)时都可以使用SCAN TABLES FROM EXTENTS 。 但是如果不存在上述的问题时,建议用SCAN TABLES FROM SEGMENTS ,因为从Segment Header获取信息更方便也更高效一些。 在PRM中同一个程序实例 同时只能使用SCAN TABLES FROM SEGMENTS 或者 SCAN TABLES FROM EXTENTS 中的一个。 使用SCAN TABLES FROM EXTENTS 后需要找到对应被TRUNCATE掉的表的原始DATA_OBJECT_ID,即左侧属性图中的一个对象,并将其DataBridge 数据搭桥传输到目标数据库中即可。 用户truncate误删 schema下的若干数据表,无法使用flashback query等技术恢复数据,尝试从之前的全备份中恢复,数据库restore速度较快,但是archivelog恢复时由于HP data Protecter的不明原因导致归档恢复十分缓慢,缓慢一个归档往往要几分钟,而需要restore数百个归档,时间上无法接受。 该案例通过PRM-DUL直接在字典模式下恢复truncate数据的功能,在不到一个小时内就恢复了数十万条数据,虽然我们无法保证不丢失一条数据,但至少帮助用户在最短时间内恢复了主要业务。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值