ABMR:在asm 环境中測试Automatic Block Recover 特性的方法



參考原文:

ABMR: How to test Automatic Block Recover Feature with ASM setup (Doc ID 1510090.1)



适用于:

Oracle Database - Enterprise Edition - Version 11.2.0.3 and later

Information in this document applies to any platform.





目标:

警告---注意:本文提供的步骤仅限于測试abmr特性的目的,而且仅能在測试环境中运行。



本文描写叙述了:在一个standby 环境中,产生block corruption 的步骤  以及 recover 坏块,

 recover 坏块 使用的是ABMR ( Auto BMR Background Process ) 特性

 

本文仅仅用于測试目的下的 使用外部冗余的asm 环境。



作为一个预先需求,主库和备库应该被适当配置并工作正常(即:同步正常)







环境是实时应用下的 physical standby database:



SQL> select DATABASE_ROLE, open_mode from v$database; --> From standby



DATABASE_ROLE    OPEN_MODE

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

PHYSICAL STANDBY READ ONLY WITH APPLY





解决方式:



1) 在asm中建立一个tablespace,

SQL> create tablespace test datafile '+/..../datafile/test1.dbf' size 1M autoextend on;

2)在上一步建立的表空间中建立表,并在表中注入測试数据。

SQL> create table abmr_test tablespace test as select * from all_objects;

SQL> commit;

--->注意:commit能够不要,由于ddl是隐含提交的。原文如此。





3)Offline the tablespace,然后把datafile 复制到文件系统中。

SQL> alter tablespace test offline;

4)调用asmcmd

 $ asmcmd -p



ASMCMD [+] > cp +/.../datafile/test1.dbf /tmp/.



5)破坏这个datafile

dd of=/tmp/test1.dbf bs=8192 conv=notrunc seek=11



6)执行dbv 确认该文件损坏(corruption)

dbv file=/tmp/test1.dbf blocksize=8192 feedback=10000





7) 把这个文件拷贝回asm,然后使用dbv验证坏块

$ asmcmd -p



ASMCMD [+] > cp /tmp/test1.dbf +/.../datafile/test1.dbf   



$ dbv file= /tmp/test1.dbf +/.../datafile/test1.dbf userid=../.. blocksize=8192 feedback=10000



8)online datafile



SQL> alter tablespace test online;



9)查询表--验证 Automatic block recovery启动并修复了损坏的blocks



SQL> select * from ABMR_TEST; <---当 AMBR starts and repairs时, 这一步会被 pause。



10)tail -f alert.log,会看到ambr进程正在工作:



Automatic block media recovery service is active.

Automatic block media recovery requested for (file# 9, block# 11)

..........

Automatic block media recovery successful for (file# 9, block# 11)





上面的測试过程是于abmr 相关的。

当使用rman 引入(制造)一个坏块,通过拷贝file到os,损坏该文件,然后restore 到原来位置,这么制造坏块,abmr是不工作的

这是由于当restore时,rman本身会检測到corrupt 而且会在alert中爆出ora-01578错误



当rman 检測到corrupt时,  the 'Auto BMR' 特性不会被触发。



參考:

Note : 1266059.1 ABMR: How to test Automatic Block Recover Feature

【翻译自mos文章】ABMR:在asm 环境中測试Automatic Block Recover 特性的方法的更多相关文章

  1. 【翻译自mos文章】回收 asm磁盘空间的方法

    回收 asm磁盘空间的方法 參考原文: How To Reclaim Asm Disk Space? (Doc ID 351866.1) 适用于: Oracle Database - Enterpri ...

  2. 【翻译自mos文章】在Oracle GoldenGate中循环使用ggserr.log的方法

    在OGG中循环使用ggserr.log的方法: 參考原文: OGG How Do I Recycle The "ggserr.log" File? (Doc ID 967932.1 ...

  3. 【翻译自mos文章】使用asm来部署 超大数据库(10TB到PB 范围)--针对oracle 10G

    使用asm来部署 超大数据库(10TB到PB 范围) 參考原文: Deployment of very large databases (10TB to PB range) with Automati ...

  4. 【翻译自mos文章】在12c数据库中,哪种audit trail 受到支持?

    在12c数据库中,哪种audit trail 受到支持? 来源于:What Audit Trail Types Are Supported For A 12c Database? (文档 ID 198 ...

  5. 【翻译自mos文章】11.2.0.4及更高版本号的asm实例中MEMORY_TARGET 和 MEMORY_MAX_TARGET的默认值和最小值

    [翻译自mos文章]11.2.0.4及更高版本号的asm实例中MEMORY_TARGET 和 MEMORY_MAX_TARGET的默认值和最小值 来源于: Default and Minimum ME ...

  6. Stack Overflow 排错翻译 - Closing AlertDialog.Builder in Android -Android环境中关闭AlertDialog.Builder

    Stack Overflow 排错翻译  - Closing AlertDialog.Builder in Android -Android环境中关闭AlertDialog.Builder 转自:ht ...

  7. 【翻译自mos文章】使用asmcmd命令在本地和远程 asm 实例之间 拷贝asm file的方法

    使用asmcmd命令在本地和远程 asm 实例之间 拷贝asm file的方法 參考原文: How to Copy asm files between remote ASM instances usi ...

  8. 【翻译自mos文章】11gR2中的asm后台进程

    11gR2中的asm后台进程 參考原文: ASM Background Processes in 11.2 (Doc ID 1641678.1) 适用于: Oracle Database - Ente ...

  9. 【翻译自mos文章】注意: ASMB process exiting due to lack of ASM file activity

    注意: ASMB process exiting due to lack of ASM file activity 參考原文: NOTE: ASMB process exiting due to la ...

随机推荐

  1. P1966 火柴排队(逆序对)

    P1966 火柴排队 题目描述 涵涵有两盒火柴,每盒装有 n 根火柴,每根火柴都有一个高度. 现在将每盒中的火柴各自排成一列, 同一列火柴的高度互不相同, 两列火柴之间的距离定义为: ∑(ai-bi) ...

  2. html5 读取本地文件

    尊重原创:http://hushicai.com/2014/03/29/html5-du-qu-ben-di-wen-jian.html HTML5为我们提供了一种与本地文件系统交互的标准方式:Fil ...

  3. Ionic学习记录(一):ionic及cordova安装、创建第一个应用、项目结构

    目录: 一.ionic的安装 二.创建第一个应用程序 三.浏览器中预览应用 四.项目结构 五.添加页面 一.ionic的安装 使用Ionic创建和开发应用程序主要通过Ionic命令行实用程序(“CLI ...

  4. 开启远程MySQL

    安装完MySQL,由于安全原因默认是没有赋予用户远程权限的,所以第一步要首先赋予用户对应的权限 一  授权 mysql> mysql -u用户名 [-pIp地址] -p #登录 mysql> ...

  5. 软件架构自学笔记——常见的软件架构(https://jiajunhuang.com/articles/2018_09_16-common_software_archtecture_pattern.md.html)

    分层模式 这种模式主要是将设计分层,每一层为其上层提供服务.例如:web开发中我们常常将某些常用的RESTful接口抽象出一个service层. 客户端-服务端模式 客户端和服务端分离,从而解耦.通过 ...

  6. 简繁体互换工具:opencc

    简繁体互换工具:opencc opencc是一个简体.繁体相互转换的命令行工具. 安装 下载软件包.在下载页面下载软件包(如1.0.4版本) 解压.通过命令解压:tar -xzvf opencc-1. ...

  7. 课上练习 script

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  8. HTTP协议探索之Cache-Control

    缓存的存与用的控制 Cache-Control指定了请求和响应遵循的缓存机制.好的缓存机制可以减少对网络带宽的占用,可以提高访问速度,提高用户的体验,还可以减轻服务器的负担. Cache-Contro ...

  9. openstack--memecache

    一.缓存系统 静态web页面: 1.工作流程: 在静态Web程序中,客户端使用Web浏览器(IE.FireFox等)经过网络(Network)连接到服务器上,使用HTTP协议发起一个请求(Reques ...

  10. 团体程序设计天梯赛-练习集-L1-037. A除以B

    L1-037. A除以B 真的是简单题哈 —— 给定两个绝对值不超过100的整数A和B,要求你按照“A/B=商”的格式输出结果. 输入格式: 输入在第一行给出两个整数A和B(-100 <= A, ...