设为首页 收藏本站
查看: 440|回复: 0

[经验分享] Oracle Rac ——Cache Fusion

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2014-12-10 08:29:09 | 显示全部楼层 |阅读模式
Cache Fusion (缓存融合)
实际意义上讲就是通过互连网络在集群各个节点内的SGA之间进行块传递,这样做的好处是避免多次将块写入磁盘,再重新读入到其他实例的缓存中。当一个块从磁盘读入RAC环境中的首个实例的sga中,该块会被赋予一个锁资源(区别于行级锁),以让其他实例知道该块正在被使用(或是读),当另一个实例请求该块的操作时,当前实例sga会传递一个块的副本给另一个实例(该块为最新,并未改变);如果内存中的块已经被改变,但改变尚未提交,会传递一个CR副本,并改变相应的锁资源的级别。从本质上讲,数据库无需多次写回磁盘或从磁盘多次读入相关实例们的sga中,在各实例中的缓存中实现共享和传递,从而避免同步实例缓存所花费的额外i/o。

应用环境:当互连网络速度远远大于磁盘I/O访问速度。

下面是cache fusion中一些概念的介绍

全局缓存服务(GCS):全局缓存(SGA)要涉及到数据块。全局缓存服务负责维护该全局缓冲存储区内的缓存一致性,确保一个实例在任何时刻想修改一个数据块时,都可获得一个全局锁资源,从而避免另一个实例同时修改该块的可能性。进行修改的实例将拥有块的当前CP版本(包括已提交的和未提交的事物)以及块的前象(post image)。如果另一个实例也请求该块,那么GCS要负责跟踪拥有该块的实例、拥有块的版本是什么,以及块处于何种资源模式。LMS进程是全局缓存服务的关键组成部分。(LMS为锁管理服务器进程,为cache fusion请求在实例间的传递服务)

全局队列服务(GES):主要负责维护字典缓存和库缓存内的一致性。字典缓存是实例的SGA内所存储的对数据字典信息的缓存,用于高速访问。由于该字典信息存储在内存中,因而在某个节点上对字典进行的修改(如DDL)必须立即被传播至所有节点上的字典缓存。GES负责处理上述情况,并消除实例间出现的差异。处于同样的原因,为了分析影响这些对象的SQL语句,数据库内对象上的库缓存锁会被去掉。这些锁必须在实例间进行维护,而全局队列服务必须确保请求访问相同对象的多个实例间不会出现死锁。LMON、LCK和LMD进程联合工作来实现全局队列服务的功能。GES是除了数据块本身的维护和管理(由GCS完成)之外,在RAC环境中调节节点间其他资源的重要服务。


1.资源模式:三种
null (默认的)
share(S) (查询)
exclusive(X) (修改block的内容,其它的实例就为null mode)

2.资源角色:两种
local:
第一次请求资源的初试模式;只有一个实例可以有这个block的dirty copy(即磁盘数据块的元数据内容)
global:
当一个Block在多个实例中变dirty时,Local就变成了Global    并最终只能由GCS发送请求写到磁盘中


下面说下  cache fusion block 是如何传输的。

环境:A,B,C,D四个节点,实例D有拥有数据块的MASTER资源权限(每个数据块都拥有一个master)

  • Read from no transfer
    假设,四个实例的sga从未缓存过该数据块,如果节点C需要向shared data disk 读一个block。 则节点C向GCS发送请求,此时请求被指向节点D(因为节点D是数据块的master),GCS把该块的资源改为share mode(S)和local role 并在D节点的GCS记录状态,并通知,C的GCS把此资源模式从Null->Share C开始I/O读磁盘读取该块。
  • Read to Write transfer
    B要读写这个数据块,B的GCS向D发出请求,D的GCS向C发出请求,要求C把数据块给B,C把数据块CP传给B,B的GCS修改块的模式Null->Exclusive(X) 且其他节点的模式为->null
  • Write to Write transfer
    A节点也要修改数据块,A的GCS向D发出请求,D的GCS指向B,如果此时该请求还没完成,则放到GES队列中,B取消修改并把block传给A (此时会强制log flush)b的块模式变为null  A收到块后加X锁,  此时,虽然B有块的cp,但不能修改,因为b块模式为null
  • Write to Read transfer
    C要读block,C的GCS向D发送请求,D指向A,A把该块的锁由X->Share模式,C收到A的块CP 取出SCN,由GCS更新元数据块CP的SCN。


通过设置参数gc_files_to_locks,可以关闭Cache Fusion。

关闭后,则别的节点要读/写数据块时,必须等待占用该块的实例节点提交,写回数据文件中。

注1:当有新的节点添加/崩溃时,原节点的锁资源会重新平衡
注2:当一个节点不再需要master,动态资源控制进程会把他移到请求频率最高的一个节点上


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-37682-1-1.html 上篇帖子: Oracle数据库安全加固记录 下篇帖子: oracle timestamp 在客户端不能显示详细数据 Oracle
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表