Oracle Rac ——Cache Fusion

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)

  1. 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读磁盘读取该块。

  2. Read to Write transfer

    B要读写这个数据块,B的GCS向D发出请求,D的GCS向C发出请求,要求C把数据块给B,C把数据块CP传给B,B的GCS修改块的模式Null->Exclusive(X) 且其他节点的模式为->null

  3. 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

  4. 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,动态资源控制进程会把他移到请求频率最高的一个节点上

时间: 2024-12-19 22:17:38

Oracle Rac ——Cache Fusion的相关文章

Oracle RAC cache fusion原理測试

Oracle RAC cache fusion是RAC最核心的工作机制.他把全部实例的SGA虚拟成一个大的SGA区,每当不同的实例请求同样的数据块,这个数据块就须要在实例间进行传递. 那究竟什么时候传递呢? 假设RAC有4个节点,当中的一个节点运行了一条SQL是全表扫描一张表,这个时候这个节点把这张表的数据载入到缓存:     方式1 :其它的节点假设须要同样的数据块会取第一个节点的数据,那是须要的时候取. 方式2 :还是第一个节点推送.   实验设定: 1.清空4个节点的share pool和

Oracle RAC cache fusion原理测试

Oracle RAC cache fusion是RAC最核心的工作机制,他把所有实例的SGA虚拟成一个大的SGA区,每当不同的实例请求相同的数据块,这个数据块就需要在实例间进行传递.那到底什么时候传递呢?加上RAC有4个节点,其中的一个节点执行了一条SQL是全表扫描一张表,这个时候这个节点把这张表的数据加载到缓存:其他的节点如果需要相同的数据块会取第一个节点的数据,那是需要的时候去,还是第一个节点推送呢?   实验设定: 1.清空4个节点的share pool和databuffer,其实当清除第

RAC Cache Fusion 原理理解

cache fusion  .   grd  .  drm   .   gcs  .   ges cache fusion 1.RAC是一个数据库执行在多个实例上.通过DLM(Distributed Lock Management):分布式锁管理器 来解决并发问题.RAC各个节点间的共享资源,为了保证每一个节点訪问数据的一致性.所以须要使用DLM来协调各个实例间的资源竞争訪问. 这个DLM在RAC中就叫Cache Fusion. 2.在cache Fusion 中,每一个数据块都被映射成Cach

Oracle RAC Study之--Cache Fusion

Oracle RAC Study之--Cache Fusion Concept of cache fusion Cache Fusion basically is about fusing the memory buffer cache of multiple instance into one single cache. For example if we have 3 instance in a RAC which is using the same datafiles and each i

Oracle RAC(Real Application Clusters)

Oracle RAC 运行于集群之上,为 Oracle 数据库提供了最高级别的可用性.可伸缩性和低成本计算能力.如果集群内的一个节点发生故障,Oracle 将可以继续在其余的节点上运行.Oracle 的主要创新是一项称为高速缓存合并的技术.高速缓存合并使得集群中的节点可以通过高速集群互联高效地同步其内存高速缓存,从而最大限度地低降低磁盘 I/O.高速缓存最重要的优势在于它能够使集群中所有节点的磁盘共享对所有数据的访问,数据无需在节点间进行分区.Oracle 是唯一提供具备这一能力的开放系统数据库

Oracle RAC中的几个IP

oracle11g开始,设置了SCAN ip,除此之外还有public ip,virtual ip,private ip,容易让人犯晕. 下面逐一解释: public ip: 类似与单实例的oracle数据库ip,主要用于管理\访问. virtual ip(vip): oracle在rac架构中专用,这个vip用于实现故障转移,当一个节点发生故障时,其vip会"浮动"到另外一个正常的节点,也即该正常节点对应着两个vip了. SCAN: Single Client Access Name

Oracle RAC LoadBalance

LoadBalance 就是把负载平均的分配到集群中的各个节点,从而提高整体的吞吐能力. Oracle 10g RAC 提供了两种不同的方法来分散负载: 1. 通过Connection Balancing,按照某种算法把用户分配到不同的节点.也可认为是纯技术的分散负载. 2. 通过Service,在应用层上进行分散,也可认为是面象业务的分散负载. 一.Connection Balancing Connection Balancing 这种负载均衡是在用户连接这个层次进行的,也就是在用户请求建立连

oracle rac IP详解

rac环境下vip/public/private IP的区别 每个节点要2块网卡, 3个IP,虚拟IP或者叫做业务IP,单个网卡当掉可以"漂"到其他网卡是继续提供服务 在Oracle RAC环境下,每个节点都会有多个IP地址,分别为Public/Private/Vip,这三个IP到底有啥区别呢?分别用在那些场合呢?来看看老外的回答. 1. private IP address is used only for internal clustering processing (Cache

ORACLE RAC集群原理

ORACLE RAC原理:在一个应用环境当中,所有的服务器使用和管理同一个数据库,目的是为了分散每一台服务器的工作量,硬件上至少需要两台以上的服务器,而且还需 要一个共享存储设备.同时还需要两类软件,一个是集群软件,另外一个就是Oracle数据库中的RAC组件.同时所有服务器上的OS都应该是同一类OS, 根据负载均衡的配置策略,当一个客户端发送请求到某一台服务的listener后,这台服务器根据我们的负载均衡策略,会把请求发送给本机的RAC组件处 理也可能会发送给另外一台服务器的RAC组件处理,