题目部分

在Oracle中,什么是OCR、OLR和VF?

     

答案部分

Oracle集群使用两种类型的文件来管理集群资源和节点:OCR(Oracle Cluster Registry,Oracle集群注册表)和VF(Voting File,表决磁盘文件)。这两种文件必须存放在共享存储上。其中,OCR相当于集群的控制文件,用于解决健忘问题,VF用于解决脑裂问题。在Oracle 11.2中引入一个新的文件,称作OLR(Oracle Local Registry,Oracle本地注册表),它只允许存放在本地。

Oracle集群软件(Clusterware)把整个集群的配置信息放在共享存储上,这个存储就是OCR磁盘(OCR Disk)。OCR是Oracle RAC配置信息仓库,它管理集群节点的相关信息及实例到节点的映射信息。因此,OCR的内容非常的重要,对OCR的操作必须确保OCR内容完整性。在整个集群运行过程中,并不是所有节点都能操作OCR磁盘,而只有一个节点能对OCR磁盘进行读写操作,这个节点叫作Master Node。在每个节点的内存中都有一份OCR内容的拷贝,这份拷贝叫作OCR Cache。同时,每个节点都有一个OCR Process来读写OCR Cache,但只有一个节点的OCR Process能读写OCR磁盘中的内容。当OCR内容发生改变时,由Master Node的OCR Process负责更新本地和其它节点的OCR Cache内容。

需要注意的是,OCR和VF的信息不会被分布到多块磁盘上,如果用一块磁盘保存OCR或VF的话,那么一定会保存完整的OCR和VF信息。

所有需要OCR内容的其它进程,比如OCSSD、EVM等都被叫作Client Process。这些进程不会直接访问OCR Cache,而是向OCR Process发送请求,借助OCR Process获得内容。如果想要修改OCR内容,也要由该节点的OCR Process向Master node的OCR process提交申请,由Master OCR Process完成物理的读写,并同步所有节点OCR Cache中的内容。

OCR的结构如下图所示:

OCR中保存着整个集群中绝大部分资源的配置信息,配置信息以“Key-Value”并且采用树形结构来保存,所以,并没有类似于数据文件的块的概念。在Oracle Clusterware安装的过程中,安装程序会提示用户指定OCR位置。用户指定的这个位置会被记录在/etc/oracle/ocr.loc(Linux或AIX)或者/var/opt/oracle/ocr.loc(Solaris系统)文件中。Oracle Clusterware在启动时会根据这里面的内容从指定位置读入OCR内容。

 1[LHRDB3:root]:/>cd /etc/oracle 2[LHRDB3:root]:/etc/oracle>ls -l 3total 3160 4drwxrwx---    2 root     dba             256 Dec 29 14:16 lastgasp 5-rw-r--r--    1 root     dba              37 Dec 29 14:10 ocr.loc 6-rw-r--r--    1 root     system            0 Dec 29 14:10 ocr.loc.orig 7-rw-r--r--    1 root     dba              92 Dec 29 14:10 olr.loc 8-rw-r--r--    1 root     system            0 Dec 29 14:10 olr.loc.orig 9drwxrwxr-x    5 root     dba             256 Dec 29 14:09 oprocd10drwxr-xr-x    3 root     dba             256 Dec 29 14:09 scls_scr11-rws--x---    1 root     dba         1606037 Dec 29 14:09 setasmgid12[LHRDB3:root]:/etc/oracle>more /etc/oracle/ocr.loc13ocrconfig_loc=+OCR14local_only=FALSE

其中,ocrconfig_loc指定OCR的位置。如果为OCR指定了镜像(Mirror),那么还会出现选项ocrmirrorconfig_loc,用于定义OCR镜像的位置。local_only指定是否是RAC系统,如果这个值为FALSE,那么表示是RAC系统,如果这个值为TRUE,那么表示是单实例系统(在使用ASM时需要)。

整个OCR的信息是树形结构,有3个大分支:分别是SYSTEM、DATABASE和CRS。每个分支下面又有许多小分支。OCR记录的信息只能由root用户修改。

OCR中通常包含下列内容

v 节点成员信息

v 数据库实例、节点以及其它的映射关系

v ASM

v 资源配置信息(vip、services等等)

v 服务特性(Service characteristics)

v Oracle集群中相关进程的信息

v CRS控制的第三方应用程序信息

可以使用命令“ocrdump -local -stdout -xml|more|grep -i \<name\>|sed -e 's/\<NAME\>//g' -e 's/\<\/NAME\>//g'|awk -F . '{print $1,$2,$3}'|uniq”将OCR中的内容输出到屏幕上,如下所示:

 1[LHRDB1:root]:/>ocrdump -local -stdout -xml|more|grep -i \<name\>|sed -e 's/\<NAME\>//g' -e 's/\<\/NAME\>//g'|awk -F . '{print $1,$2,$3}'|uniq 2SYSTEM   3SYSTEM crs  4SYSTEM crs usersecurity 5SYSTEM crs deny 6SYSTEM crs user_default_dir 7SYSTEM ORA_CRS_HOME  8SYSTEM WALLET  9SYSTEM GNS 10SYSTEM version 11SYSTEM version localhost12SYSTEM version activeversion13SYSTEM GPnP 14SYSTEM GPnP profiles15SYSTEM css 16SYSTEM css nodenum_hint17SYSTEM network 18SYSTEM network haip19SYSTEM OHASD 20SYSTEM OHASD DM21SYSTEM OHASD SERVERPOOLS22SYSTEM OHASD SERVERS23SYSTEM OHASD TYPES24SYSTEM OHASD RESOURCES25SYSTEM CRS 26SYSTEM CRS JOIN_SIGNATURE27SYSTEM OLR 28SYSTEM OLR MANUALBACKUP29SYSTEM OCR 30SYSTEM OCR BACKUP31DATABASE  32DATABASE NODEAPPS 33DATABASE VIP_RANGE 34DATABASE LOG 35DATABASE ASM 36DATABASE DATABASES 37CRS

本文选自《Oracle程序员面试笔试宝典》,作者:小麦苗

---------------优质麦课------------

详细内容可以添加麦老师微信或QQ私聊。

About Me:小麦苗

● 本文作者:小麦苗,只专注于数据库的技术,更注重技术的运用

● 作者博客地址:http://blog.itpub.net/26736162/abstract/1/

● 本系列题目来源于作者的学习笔记,部分整理自网络,若有侵权或不当之处还请谅解

● 版权所有,欢迎分享本文,转载请保留出处

● QQ:646634621  QQ群:618766405

● 提供OCP、OCM和高可用部分最实用的技能培训

● 题目解答若有不当之处,还望各位朋友批评指正,共同进步

DBA宝典

长按下图识别二维码或微信扫描下图二维码来关注小麦苗的微信公众号:xiaomaimiaolhr,学习最实用的数据库技术。

©著作权归作者所有:来自51CTO博客作者小麦苗DB宝的原创作品,如需转载,请注明出处,否则将追究法律责任

更多相关文章

  1. 【DB笔试面试739】在Oracle中,如何获取集群的名称(Cluster name)?
  2. 【DB笔试面试726】在Oracle中,RAC中的Public、Private、Virtual、
  3. 使用kubeadm部署Kubernetes v1.13.3
  4. OpenShift容量规划方法
  5. 让我们重新认识OpenShift系列1
  6. 容器调度策略:让我们重新认识OpenShift系列4
  7. 内核窥探|在kernel中的链表,其他的链表真的弱爆了
  8. 与亲生的Redis Cluster,来一次亲密接触
  9. 【DB笔试面试712】在Oracle中,启动和关闭集群的命令是什么?

随机推荐

  1. 详细介绍解析Xml四种方法的示例代码
  2. 详细介绍测试几个xml的问题的案例
  3. XML布局文件的代码案例分享
  4. JS读取XML数据的示例代码分享
  5. 具体介绍使用XmlReader读取xml文件的代码
  6. 详解XML中Node和Element区别的示例代码
  7. Xml序列化的图文代码详解
  8. XML学习(三) js保存xml的示例代码分享
  9. XML串行化的示例代码分享
  10. 详细介绍XML操作总结的示例代码