cache-fusion笔记
GRD (global resource directory)保存着所有实例中资源的分布情况
GCS (global cache service)具体执行cache fusion 工作的服务,对应进程LMSn
GES (global enqueues service)协调实例之间的GCS完成数据传递工作,完成non-cache fusion资源的管理工作,对应进程LMD.

Cache-fusion全局锁
全局锁的分配是通过每个节点的GES服务协调完成的,每个时间点只有一个实例能够修改相同的数据块,通过GES的协调获得块的全局锁之后,GCS负责实例间数据块的传递工作。(cache fusion的频繁使用会导致数据性能的下降)。
GES(全局队列服务)负责维护字典缓存和库缓存内的一致性。字典缓存是实例的SGA内所存储的对数据字典信息的缓存,用于高速访问数据字典信息。GES控制数据库中所有的library cache锁和dictionary cache锁。
数据一致性
实例A的一个事务更新了一个数据块,但没有提交,这个时候实例B查询包含事务的这个数据块,那么实例A会将UNDO段中的一致性数据块传送给实例B,实例B中存放的该数据块就是CR状态的数据块,并非是当前最新的数据块。如果这个时候实例B要更新这个数据块,实例A会将SGA中当前的数据块降级,然后传递给实例B,实例B中存放的数据块就是当前最新的数据块。(相同的块在不同实例中分布体现在GRD中,GRD能展示块的分布图)
Past Image(PI)是维护脏块的拷贝,GCS管理PI,GCS在实例失败恢复的时候会用到PI版本的块。Oracle允许即使操作块的事务未提交,如果其他实例有事务修改相同块的不同行,块也能在实例间传递,但是必须保留原来实例中未提交的块,这个块就是PI.
(1) 并行操作过程中的PI
在多节点实例并行操作的过程中,当实例请求修改块时,GCS服务的LMSn进程会将数据块从最后修改此块的实例传送给请求的实例,而LMSn会在原来持有此块的实例中保留此数据库的PI版本。
(2) 资源的磁盘写
因为可能在集群的多个实例中存在多个被修改过的数据块,由GCS管理的写规则必须确保将最近版本的数据块写入磁盘中。GCS还必须确保所有之前的版本已从其他cache中清除。对数据块的写可以由任何持有此数据块的当前版本或PI数据块的实例发起。

Cache fusion应用场景
(1) 多节点实例并行读
实例A从吸盘读取一个块的时候,该块在GRD中记录的状态为SCUR,实例B查询该表,通过cache fusion获取该块,由于并不对该块进行更改,所以实例A块的状态没有发生变化,在实例B中的块的状态是CR。实例C再次执行相同的查询从实例A获取该块,同样实例C中的块状态也是CR。
(2) 多节点实例并行读和写
实例A从磁盘读取数据块到内存中,记录块的状态为SCUR。实例B要更新该块中的行,必须获得排他的锁,且更新的块必须是当前最新的块,实例B通过cache fusion将实例A的块拷贝到自己的buffer cache中,同时实例A的块状态变为CR,实例B中块的状态是XCUR。
(3) 多节点实例并行写
实例A执行UPDATE语句从磁盘读取块到实例中,块的状态为XCUR。实例B要更新同一个块的其他行记录,实例A的块状态变为CR,实例B通过cache fusion将实例A的块拷贝到实例B的buffer cache中,实例B上块的状态为XCUR。如果实例C也要更新同一块,实例C必须等待实例B执行完成后,实例B的状态变更为CR,通过cache fusion将实例B上的块拷贝到实例C,并修改修改实例C块状态为XCUR。以上操作,实例A和实例B中保存的CR状态的块都是PI版本。
(参考《构建最高可用RAC》)
cache-fusion笔记的更多相关文章
- RAC Cache Fusion 原理理解
cache fusion . grd . drm . gcs . ges cache fusion 1.RAC是一个数据库执行在多个实例上.通过DLM(Distributed ...
- Oracle RAC cache fusion原理測试
Oracle RAC cache fusion是RAC最核心的工作机制.他把全部实例的SGA虚拟成一个大的SGA区,每当不同的实例请求同样的数据块,这个数据块就须要在实例间进行传递. 那究竟什么时候传 ...
- oracle rac cache fusion
转载自 http://blog.csdn.net/tianlesoftware/article/details/6534239 Introduction This post is about orac ...
- 1011MySQL Query Cache学习笔记
转自:http://blog.chinaunix.net/uid-16844903-id-321156.html 测试环境 MySQL 5.5 innodb_version 1.1.6 MySQL Q ...
- Guava Cache 使用笔记
https://www.cnblogs.com/parryyang/p/5777019.html https://www.cnblogs.com/shoren/p/guava_cache.html J ...
- 缓存融合(Cache Fusion)介绍
概念 简单地说,缓存融合就是把Oracle RAC数据库中所有数据库缓存作为一个共享的数据库缓存,并被RAC中的所有节点共享.它是实现RAC的基本技术. 缓存融合主要有如下四个功能: (1) 提供扩展 ...
- RAC Cache Fusion Background Processes
Acdante--每日三省吾身-- . 什么是缓存融合? .缓存融合工作原理? .缓存融合关键进程以及作用?
- Oracle RAC学习笔记01-集群理论
Oracle RAC学习笔记01-集群理论 1.集群相关理论概述 2.Oracle Clusterware 3.Oracle RAC 原理 写在前面: 最近一直在看张晓明的大话Oracle RAC,真 ...
- Varnish Cache
1 Varnish简介 Varnish是高性能且开源的反向代理服务器和HTTP加速器(cache server).其开发者Poul-Henning Kamp是FreeBSD核心的开发人员之一.Varn ...
随机推荐
- SD从零开始59-61,跨公司的库存转移,Interface 修改,可用性检查和需求传递
[原创]SD从零开始59 跨公司的库存转移处理流程 库存转移流程Stock Transfer Procedure 2个工厂间的库存转移能够使用不同的流程来执行: 只执行一个库存转移记账的流程使用MM库 ...
- FI配置清单-概要
1.编辑公司代码 T-Code:OX02 路径:IMG >企业结构Enterprise >定义Definition >财务会计 Financial Accounting>编辑, ...
- Windows7安装 nginx+php 后访问.php文件出现 “No input file specified.” 的解决办法
在Windows7上安装了Nginx+PHP,参考教程为 https://www.cnblogs.com/anlia/p/5916758.html 启动 nginx 后,在浏览器中输入localhos ...
- AndroidGradle最实用的指南
AndroidStudio目前已经成为Android开发人员的主流工具,而Gradle的原理,配置,使用仍然是很多android开发人员感到困惑的地方.网上虽然有很多相关文档,但是要么是只会用但是不知 ...
- 类与接口(二)java的四种内部类详解
引言 内部类,嵌套在另一个类的里面,所以也称为 嵌套类; 内部类分为以下四种: 静态内部类 成员内部类 局部内部类 匿名内部类 一.静态内部类 静态内部类: 一般也称"静态嵌套类" ...
- qt多线程信号槽传输方式
//简单介绍一下QT信号与槽的连接方式: //Qt::AutoConnection表示系统自动选择相应的连接方式,如果信号与槽在同一线程,就采用Qt::DirectConnection, //如 ...
- jQuery EasyUI datagrid列名包含特殊字符会导致表格错位
首先申明:本文所述的Bug存在于1.3.3以及更高版本中,其它低版本,本人未测试,太老的版本不想去折腾了. 洒家在写前端的SQL执行工具时,表格用了 jQuery EasyUI datagrid,因为 ...
- Azure 中虚拟机的备份和还原选项
可以通过定期创建备份来保护数据. 有多个备份选项可用于 VM,具体取决于使用案例. Azure 备份 若要备份运行生产工作负荷的 Azure VM,请使用 Azure 备份. Azure 备份对 Wi ...
- SQL Server中事务transaction如果没写在try catch中,就算中间语句报错还是会提交
假如我们数据库中有两张表Person和Book Person表: CREATE TABLE [dbo].[Person]( ,) NOT NULL, ) NULL, ) NULL, [CreateTi ...
- VC 调试版(Debug Version)和发行版(Release Version)
调试是纠正或修改代码,使之可以顺利地编译.运行的过程.为此,VC IDE提供了功能强大的调试和跟踪工具. 1.1.1 调试版(Debug Version)和发行版(Release Version) 开 ...