Oracle RAC cache fusion是RAC最核心的工作机制。他把全部实例的SGA虚拟成一个大的SGA区,每当不同的实例请求同样的数据块,这个数据块就须要在实例间进行传递。

那究竟什么时候传递呢?

假设RAC有4个节点,当中的一个节点运行了一条SQL是全表扫描一张表,这个时候这个节点把这张表的数据载入到缓存;

    方式1 :其它的节点假设须要同样的数据块会取第一个节点的数据,那是须要的时候取。

    方式2 :还是第一个节点推送。

  实验设定:

1.清空4个节点的share pool和databuffer。事实上当清除第一个节点的时候。其它的节点都已经清除了,从运行清除语句的时间就能够看出。清除后查下各节点data buffer中有没有缓存将要运行的SQL的表。

2.在第一个节点上运行一条SQL.,在其它的节点上看data buffer中是否缓存SQL的表,假设有,说明是数据块是主动推送的。

  实验结论:

数据块从第运行的节点推送到其它的节点上,RAC尽管使得使用的资源多了几倍。但因为cache fusion这个特性,上了RAC后的系统系统是否有提升还是未知之数。

---清理4个节点(54,55,56,57)shared_pool和buffer_cache

如今节点54上清理share pool和data buffer

SQL> alter system flush shared_pool;

系统已更改。

SQL> alter system flush buffer_cache;

系统已更改。

---在其它的节点55,56,57上相同运行



---在第54个节点測试语句


SQL> SELECT COUNT(1)

  2  FROM MM_DISTRIBUTION W

  3  WHERE    W.DATA_AREA LIKE '03'

  4    || '%'

  5  AND W.CREATE_DATE > TO_DATE('2013-01-01', 'yyyy-mm-dd');

已用时间:  00: 00: 02.40

运行计划

----------------------------------------------------------

Plan hash value: 3507380501

-------------------------------------------------------------------------------------------------------

| Id  | Operation           | Name            | Rows  | Bytes | Cost (%CPU)| Time     | Pstart| Pstop |

-------------------------------------------------------------------------------------------------------

|   0 | SELECT STATEMENT    |                 |     1 |    13 |  5209   (2)| 00:01:03 |       |       |

|   1 |  SORT AGGREGATE     |                 |     1 |    13 |            |          |       |       |

|   2 |   PARTITION LIST ALL|                 | 43668 |   554K|  5209   (2)| 00:01:03 |     1 |     2 |

|*  3 |    TABLE ACCESS FULL| MM_DISTRIBUTION | 43668 |   554K|  5209   (2)| 00:01:03 |     1 |     2 |

-------------------------------------------------------------------------------------------------------

Predicate Information (identified by operation id):

---------------------------------------------------

   3 - filter("W"."CREATE_DATE">TO_DATE('2013-01-01 00:00:00', 'yyyy-mm-dd hh24:mi:ss') AND

              "W"."DATA_AREA" LIKE '03%')

统计信息

----------------------------------------------------------

       2997  recursive calls

          0  db block gets

      24196  consistent gets

      23581  physical reads

          0  redo size

        334  bytes sent via SQL*Net to client

        338  bytes received via SQL*Net from client

          2  SQL*Net roundtrips to/from client

         39  sorts (memory)

          0  sorts (disk)

          1  rows processed



SQL> /



已用时间:  00: 00: 00.28



运行计划

----------------------------------------------------------

Plan hash value: 3507380501

-------------------------------------------------------------------------------------------------------

| Id  | Operation           | Name            | Rows  | Bytes | Cost (%CPU)| Time     | Pstart| Pstop |

-------------------------------------------------------------------------------------------------------

|   0 | SELECT STATEMENT    |                 |     1 |    13 |  5209   (2)| 00:01:03 |       |       |

|   1 |  SORT AGGREGATE     |                 |     1 |    13 |            |          |       |       |

|   2 |   PARTITION LIST ALL|                 | 43668 |   554K|  5209   (2)| 00:01:03 |     1 |     2 |

|*  3 |    TABLE ACCESS FULL| MM_DISTRIBUTION | 43668 |   554K|  5209   (2)| 00:01:03 |     1 |     2 |

-------------------------------------------------------------------------------------------------------

Predicate Information (identified by operation id):

---------------------------------------------------

   3 - filter("W"."CREATE_DATE">TO_DATE('2013-01-01 00:00:00', 'yyyy-mm-dd hh24:mi:ss') AND

              "W"."DATA_AREA" LIKE '03%')

统计信息

----------------------------------------------------------

          0  recursive calls

          0  db block gets

      23554  consistent gets

          0  physical reads

          0  redo size

        334  bytes sent via SQL*Net to client

        338  bytes received via SQL*Net from client

          2  SQL*Net roundtrips to/from client

          0  sorts (memory)

          0  sorts (disk)

          1  rows processed



---在4个节点查看share_pool中的SQL是否同步

select sql_text from v$sql s where sql_text like '%MM_DISTRIBUTION%';



---在4个节点查看測试buffer_cache。能够看到其它的3个节点都已同步缓存数据

select count(b.object_name)

  from sys.v_x$bh a, user_objects b

 where a.OBJ = b.object_id

   and b.object_name = 'MM_DISTRIBUTION'

   and a.STATE <> 0;     ---state=0表示free。其它表示已占用

COUNT(B.OBJECT_NAME)

--------------------

               23543

Oracle RAC cache fusion原理測试的更多相关文章

  1. RAC Cache Fusion 原理理解

    cache fusion  .   grd  .  drm   .   gcs  .   ges cache fusion  1.RAC是一个数据库执行在多个实例上.通过DLM(Distributed ...

  2. oracle rac cache fusion

    转载自 http://blog.csdn.net/tianlesoftware/article/details/6534239 Introduction This post is about orac ...

  3. Oracle rac架构和原理

        Oracle RAC Oracle Real Application Cluster (RAC,实时应用集群)用来在集群环境下实现多机共享数据库,以保证应用的高可用性:同时可以自动实现并行处理 ...

  4. 关于Oracle RAC中SCN原理和机制的探索

    今天看书时看到了关于RAC中SCN的问题,为了进一步搞清楚其内部原理和机制,对该问题进行了广泛的查阅和搜索,遗憾的是,可以参考的资料很少,网上大部分是人云亦云的帖子,其中,详细介绍其内部原理和机制的资 ...

  5. oracle capability i/o(压力測试数据库serveri/o性能)

    今天是2014-04-21,今天简单仅仅说明一下怎么影响重做数据的一个因素,那就是i/o吞吐量,oracle的介质恢复依赖于i/o,假设i/o存在瓶颈,那么势必会影响备库的介质恢复. 那么i/o st ...

  6. RAC Cache Fusion Background Processes

    Acdante--每日三省吾身-- . 什么是缓存融合? .缓存融合工作原理? .缓存融合关键进程以及作用?

  7. 学习使用Jmeter做压力測试(一)--压力測试基本概念

    一.性能測试的概念         性能測试是通过自己主动化的測试工具模拟多种正常峰值及异常负载条件来对系统的各项性能指标进行測试.负载測试和压力測试都属于性能測试,两者能够结合进行. 通过负载測试, ...

  8. Oracle Enterprise Linux 64-bit 下Oracle11g的监听配置改动及測试步骤

    測试环境:Oracle Enterprise Linux 64-bit (5.8版本号) + Oracle 11g 64位 相关说明: Oracle11g64位软件的安装位置为/u01/app/ora ...

  9. 測试oracle 11g cluster 中OLR的重要性

     測试oracle 11g cluster 中OLR的重要性 called an Oracle Local Registry (OLR): each node in a cluster has a ...

随机推荐

  1. C#保存图片到文件夹区分8位和24位

    1.保存图像--24位位图(显示的图像,包括增加结果到界面上的数据) Image image2 = default(Image); image2 = cogRecordDisplay1.CreateC ...

  2. Knockout v3.4.0 中文版教程-15-控制文本内容和外观-attr绑定

    6. attr绑定 目的 attr绑定可以给关联DOM元素的任何属性赋值.这个绑定很棒,比如,当你想要设置通过视图模型给元素的title属性.img标签的src属性或超链接的href值,当视图模型对应 ...

  3. lfyzoj104 Counting Swaps

    问题描述 给定你一个 \(1 \sim n\) 的排列 \(\{p_i\}\),可进行若干次操作,每次选择两个整数 \(x,y\),交换 \(p_x,p_y\). 请你告诉穰子,用最少的操作次数将给定 ...

  4. android 之 ListView相关

    ListView是一种列表视图,其将ListAdapter所提供的各个控件显示在一个垂直且可滚动的列表中.需要注意的为创建适配器并将其设置给ListView. 1.ArrayAdapter Array ...

  5. 详解Java类的生命周期

    引言 最近有位细心的朋友在阅读笔者的文章时,对Java类的生命周期问题有一些疑惑,笔者打开百度搜了一下相关的问题,看到网上的资料很少有把这个问题讲明白的,主要是因为目前国内Java方面的教材大多只是告 ...

  6. mysql无法启动,报错 Can't start server: can't create PID file: No space left on device

    然后看mysql日志文件 出现Can't start server: can't create PID file: No space left on device 这个错误. 提示磁盘空间不足 后用d ...

  7. main()中的参数argc, argv

    转自:http://blog.csdn.net/eastmount/article/details/20413773 一.main()函数参数 通常我们在写主函数时都是void main()或int ...

  8. Ubuntu16.04 on ThinkPad E455 不能识别耳机 的解决方法

    去年 (2016) 2月份在ThinkPad E455 上安装了Ubuntu 14.04 LTS (dual boot with Windows 10, upgraded to Ubuntu 16.0 ...

  9. 刷题总结——bzoj1725(状压dp)

    题目: 题目描述 Farmer John 新买了一块长方形的牧场,这块牧场被划分成 N 行 M 列(1<=M<=12; 1<=N<=12),每一格都是一块正方形的土地. FJ  ...

  10. yum update 出错解决办法

    卸载掉yum和python 于是我卸载了python和yum,觉得自己重新安装python和yum. 步骤1:卸载python rpm -qa|grep python|xargs rpm -e --a ...