【OCR】使用ocrdump工具获取集群注册表(OCR)的详细内容

Oracle的OCR(Oracle Cluster Registry)称作Oracle集群注册表,OCR提供了集群软件与其他应用程序进程之间共享信息的途径。OCR记录了集群软件所管理资源的信息,以键值对的树状结构进行存储。

Oracle提供了ocrdump工具用来获取OCR的内容,通过了解其结构和内容有助于对OCR进行深入的了解。

1.ocrdump工具自带的帮助信息
[root@rac2 crs]# ocrdump -help
Name:
        ocrdump - Dump contents of Oracle Cluster Registry to a file.

Synopsis:
        ocrdump [|-stdout] [-backupfile ] [-keyname ] [-xml] [-noheader]

Description:
        Default filename is OCRDUMPFILE. Examples are:

        prompt> ocrdump
        writes cluster registry contents to OCRDUMPFILE in the current directory

        prompt> ocrdump MYFILE
        writes cluster registry contents to MYFILE in the current directory

        prompt> ocrdump -stdout -keyname SYSTEM
        writes the subtree of SYSTEM in the cluster registry to stdout

        prompt> ocrdump -stdout -xml
        writes cluster registry contents to stdout in xml format

Notes:
        The header information will be retrieved based on best effort basis.
        A log file will be created in
        $ORACLE_HOME/log//client/ocrdump_.log. Make sure
        you have file creation privileges in the above directory before
        running this tool.

通过这个帮助提示文档可以对用法有一个比较全面的了解。

2.使用ocrdump生成OCR的转储文件
注意,由于Oracle 10.2.0.1的Bug所限,在使用该工具之前需要将Oracle集群软件升级到10.2.0.4(当然,如果OCR的备份文件是存放在OCR兼容的存储设备上,将不会触发Bug,因此也不用对其进行升级)。有关该Bug的更多描述请参见《【OCR】无法转储OCR备份文件内容——PROT-302: Failed to initialize ocrdump》(http://space.itpub.net/519536/viewspace-677936)。
1)确定Oracle集群软件为10.2.0.4
[root@rac2 ~]# /oracle/app/crs/bin/crsctl query crs softwareversion
CRS software version on node [rac2] is [10.2.0.4.0]

2)获取OCR的备份目录信息
[root@rac2 ~]# ocrconfig -showbackup

rac2     2010/11/10 04:33:24     /oracle/app/crs/cdata/crs

rac2     2010/11/10 01:08:28     /oracle/app/crs/cdata/crs

rac2     2010/11/09 21:43:20     /oracle/app/crs/cdata/crs

rac2     2010/11/09 21:43:20     /oracle/app/crs/cdata/crs

rac1     2010/11/06 00:57:14     /oracle/app/crs/cdata/crs

3)获取OCR备份目录中的OCR备份文件
[root@rac2 ~]# cd /oracle/app/crs/cdata/crs
[root@rac2 crs]# ls -ltr
total 23560
-rw-r--r-- 1 root root 4812800 Nov  9 21:43 backup02.ocr
-rw-r--r-- 1 root root 4812800 Nov  9 21:43 day.ocr
-rw-r--r-- 1 root root 4812800 Nov 10 01:08 backup01.ocr
-rw-r--r-- 1 root root 4812800 Nov 10 01:08 day_.ocr
-rw-r--r-- 1 root root 4812800 Nov 10 04:33 backup00.ocr

4)转储OCR备份文件
[root@rac2 crs]# /oracle/app/crs/bin/ocrdump -backupfile backup00.ocr
[root@rac2 crs]# ls -ltr
total 23800
-rw-r--r-- 1 root root 4812800 Nov  9 21:43 backup02.ocr
-rw-r--r-- 1 root root 4812800 Nov  9 21:43 day.ocr
-rw-r--r-- 1 root root 4812800 Nov 10 01:08 backup01.ocr
-rw-r--r-- 1 root root 4812800 Nov 10 01:08 day_.ocr
-rw-r--r-- 1 root root 4812800 Nov 10 04:33 backup00.ocr
-rw-r--r-- 1 root root  241447 Nov 10 08:15 OCRDUMPFILE

亦可以使用“-xml”选项以XML格式进行输出
[root@rac2 crs]# /oracle/app/crs/bin/ocrdump -xml -backupfile backup00.ocr xml_backup00
[root@rac2 crs]# ls -ltr
total 24188
-rw-r--r-- 1 root root 4812800 Nov  9 21:43 backup02.ocr
-rw-r--r-- 1 root root 4812800 Nov  9 21:43 day.ocr
-rw-r--r-- 1 root root 4812800 Nov 10 01:08 backup01.ocr
-rw-r--r-- 1 root root 4812800 Nov 10 01:08 day_.ocr
-rw-r--r-- 1 root root 4812800 Nov 10 04:33 backup00.ocr
-rw-r--r-- 1 root root  241447 Nov 10 08:15 OCRDUMPFILE
-rw-r--r-- 1 root root  392832 Nov 10 08:24 xml_backup00

如果未指定输出的文件名,系统默认的转储名字是“OCRDUMPFILE”。

5)分别查看两种形式的转储文件内容
[root@rac2 crs]# vi OCRDUMPFILE
11/10/2010 08:15:52
backup00.ocr
/oracle/app/crs/bin/ocrdump.bin -backupfile backup00.ocr

[SYSTEM]
UNDEF :
SECURITY : {USER_PERMISSION : PROCR_ALL_ACCESS, GROUP_PERMISSION : PROCR_READ, OTHER_PERMISSION : PROCR_READ, USER_NAME : root, GROUP_NAME : root}

[SYSTEM.css]
UNDEF :
SECURITY : {USER_PERMISSION : PROCR_ALL_ACCESS, GROUP_PERMISSION : PROCR_READ, OTHER_PERMISSION : PROCR_READ, USER_NAME : root, GROUP_NAME : root}

[SYSTEM.css.interfaces]
UNDEF :
SECURITY : {USER_PERMISSION : PROCR_ALL_ACCESS, GROUP_PERMISSION : PROCR_CREATE_SUB_KEY, OTHER_PERMISSION : PROCR_READ, USER_NAME : oracle, GROUP_NAME : oinstall}
……省略剩余输出……


[root@rac2 crs]# vi xml_backup00


11/10/2010 08:24:49
backup00.ocr
/oracle/app/crs/bin/ocrdump.bin -xml -backupfile backup00.ocr xml_backup00


SYSTEM
UNDEF

PROCR_ALL_ACCESS
PROCR_READ
PROCR_READ
root
root


SYSTEM.css
UNDEF

PROCR_ALL_ACCESS
PROCR_READ
PROCR_READ
root
root


SYSTEM.css.interfaces
UNDEF

PROCR_ALL_ACCESS
PROCR_CREATE_SUB_KEY
PROCR_READ
oracle
oinstall
……省略剩余输出……

3.OCR的树形结构
全面查看OCR的内容后可以总结出如下的树形结构。
root
├─SYSTEM
│  ├─css
│  ├─language
│  ├─version
│  ├─ORA_CRS_HOME
│  ├─local_only
│  ├─evm
│  ├─crs
│  └─OCR
├─DATABASE
│  ├─NODEAPPS
│  ├─LOG
│  ├─ASM
│  ├─DATABASES
│  │  ├─SERVICE
│  │  └─INSTANCE
│  └─ONS
└─CRS

简单对上述三类键值的功能做下述简要描述:
1)SYSTEM键包含了与Oracle Clusterware主要进程CSSD、CRSD和EVMD的相关数据;
2)DATABASE键包含了在Oracle Clusterware注册的RAC数据库相关的数据;
3)OCR键记录了与资源概要文件相关的信息,维护其他注册到Oracle Clusterware的应用程序的可用性。

4.小结
OCR作为Oracle RAC集群环境中的重要资源,建议对其内容进行深入的理解。

Good luck.

secooler
10.11.10

-- The End --

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/519536/viewspace-678008/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/519536/viewspace-678008/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值