Oracle DRM原理是什么

53次阅读
没有评论

共计 2068 个字符,预计需要花费 6 分钟才能阅读完成。

本篇内容主要讲解“Oracle DRM 原理是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让丸趣 TV 小编来带大家学习“Oracle DRM 原理是什么”吧!

Buffer: 对于 RAC 数据库,当一个数据块被读入到 buffer cache 后,我们就称其为 buffer , cache fusion 会将这个 buffer 作为 resource 来管理。

Master:在 RAC 数据库的世界里,每一个 resource 都会有一个 master 实例,这个 master 实例会在 shared pool 中(例如:gcs resource 和 ges resource 部分)分配一些空间来存放和这个资源相关的信息

例如:哪一个实例拥有了这个 buffer 的最新版本,哪一个实例拥有了这个 buffer 的什么级别的 lock 等等。并且,负责维护和这个资源的状态。

接下来,我们对 RAC 环境中,访问一个 buffer 的过程进行简单的描述。我们以一个 4 节点的 RAC 数据库为例。

注意,我们只会列出比较典型的一种情况,不会把所有可能的情况都一一列出,而且只是把步骤进行了简单的介绍。

步骤 1:实例 3 需要以 X(exclusive) 方式访问 buffer1, 向 master 实例(1)发出了请求。

步骤 2:master 实例(1)发现实例 2 以 X 方式持有 buffer1,之后通知实例 2 释放 X lock,并把 buffer1 发送给实例 3。

步骤 3: 实例 2 释放 X lock,并把最新版本的 buffer1 发送给实例 3。

步骤 4:实例 3 获得 buffer1, 并通知 master 实例(1)更新资源 buffer1 的最新状态。

从上面的步骤,我们不难看出,在 RAC 数据库中,当我们访问一个 buffer 的时候,最多会有 3 个实例参与其中

master 实例,holder(持有者)实例 和 requestor(申请者) 实例。2 种数据传输会出现,message: 用于和 lock 相关的信息传输,data:用于传输 buffer

同时,根据上面的步骤我们也自然会想到,如果 master 和 requestor 在同一个实例上

那么就可以减少实例之间 message 的传输并且访问的代码路径(code path)会更短,从而提高性能

但是每个 buffer 在被读取到 buffer cache 时,master 节点的选择是随机的。

基于这种考虑,oracle 从 10g 开始,推出了一个新特性 DRM(Dynamic Resource management)

DRM 的主要功能是,根据一段时间内(默认 10 分钟)

每个实例,对某一个数据库对象的 (10gR1 以数据文件为单位) 的访问次数和方式,来决定数据库对象对应的 buffer 应该被 mastering 到哪一个实例。

在指定时间内,如果某一个实例访问某个数据库对象次数高于其他实例一定倍数(默认 50 倍),则 oracle 会把这个对象所有的 buffer 的 master 信息

转移到对应实例(注意:不是转移 buffer), 转移的过程是渐进式的。

当 oracle 决定将一个 buffer 的 master 实例确定到本地实例后,会对这个 buffer 上加上 affinity lock,来实现快速的访问

这也是我们经常提到的 object affinity 的由来

接下来,我们对 DRM 的基本步骤进行介绍。

1. Oracle 停止所有在需要进行 remastering 的 buffer 上的操作。注意:DRM 是渐进的,也就是说以 windows 为单位,每次对一部分的 buffer 进行 remastering 操作

2. Lmon 通知所有实例,准备进行 remastering

3. 在旧的 master 实例清除对应 buffer 的 master 信息

4. 将 master 信息传递给新的 master 实例

5. 在新的 master 实例构建资源的最新状态

6. 结束,并释放所有之前所有步骤占用的资源

然后,我们对 DRM 相关的一些参数进行简单的介绍。

_gc_policy_time:单位为分钟,控制 DRM 统计实例访问 buffer 次数的时间间隔,默认为是 10 分钟

_gc_affinity_ratio:控制进行 remastering 所需要达到的最小比例(阀值),默认为 50

也就是说,如果某个实例在 10 分钟(_gc_policy_time)之内,访问某个数据库对象的次数大于其他所有实例 50 倍时 (注意:是 50 倍,而不是 50 次)

对该数据库对象的 buffer 进行 remastering

注意:请不要轻易修改以上参数的值,除非有技术支持

最后,如果您遇到了和 DRM 相关的问题,建议您查看以下的信息。

1. Lmon,lmd,lms 和 diag 进程的 trace file,来确认问题出现在 DRM 的哪一步和 lms,lmon,lmd 进程的状态。

2. AWR 和 ASH report,确认那些等待事件持续了很长时间,以及 lmon,lms 和 lmd 的状态。

3. 参照 note 1492990.1 获取 DMR 诊断脚本输出。

到此,相信大家对“Oracle DRM 原理是什么”有了更深的了解,不妨来实际操作一番吧!这里是丸趣 TV 网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-26发表,共计2068字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)