文章转自:http://m.bianceng.cn/database/Oracle/201407/42884.htm

测试环境:版本11gR2
SQL> select * from v$version where rownum=1;

BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production

一、逻辑读的过程
 1、Oracle以每个块的文件号、块号和类型做HASH运算,得到HASH值。根据HASH值,到HASH表中取出指定块的内存地址
 2、获取CBC Latch(实验的重点测试部分)
 3、根据HASH值,搜索CBC链表
 4、根据DBA找到BH(Buffer Header)加Buffer Pin
 5、加完Buffer Pin马上释放CBC Latch
 6、访问Buffer开始fetch数据
 7、获取CBC Latch
 8、释放Buffer Pin
 9、释放CBC Latch

二、取T1表的第一行数据及ROWID,根据dbms_rowid包查出这行数据的文件号、块号
SQL> select rowid,dbms_rowid.rowid_relative_fno(rowid)
file#,dbms_rowid.rowid_block_number(rowid) block#,id,name from
gyj.t1 where rownum=1;

ROWID                   FILE#     BLOCK#         ID NAME
------------------ ---------- ---------- ---------- ----------
AAASP9AAGAAAACHAAA          6       135          1 aaaaa

这里的DBA(Data Block Address)就是由6号文件和135号块组成

三、根据文件号块号获取CBC Latch的地址
SQL> select hladdr from x$bh where file#=6 and dbablk=135;
HLADDR
----------------
00000003A4282A90

四、根据CBC Latch的地址可以查出这个CBC Latch被获得的次数
1.获取CBC Latch的次数为245
SQL> select addr,name,gets from v$latch_children  where addr='00000003A4282A90';
ADDR             NAME                                                                   GETS
---------------- ---------------------------------------------------------------- ----------
00000003B09F7C58 cache buffers chains                                                    245

2.再次读取T1表的第一数据,即产生一次逻辑读
SQL>select id,name from gyj.t1 where rowid='AAASP9AAGAAAACHAAA';
  ID      NAME
  -------- ------------
1     gyj1

3.CBC Latch的次数变为247,说明一次逻辑读产生两次CBC Latch
SQL> select addr,name,gets from v$latch_children  where addr='00000003A4282A90';
ADDR             NAME                                                                   GETS
---------------- ---------------------------------------------------------------- ----------
00000003A4282A90 cache buffers chains                                                    247

五、查本会话下的进程号
SQL> select spid from v$session s,v$process b where s.paddr=b.addr and s.sid in(select sid from v$mystat where rownum=1);

SPID
------------------------
2416

六、利用Dtrace工具跟踪
1.编写个简单的dtrace脚本
vi dtrace.d

#!/usr/sbin/dtrace -s -n
dtrace:::BEGIN
{
       i=1;
}

pid$1:::entry
{
       printf("i=%d PID::entry:==%s:%s:%s:%s %x %x %x %d %x %x",i,
probeprov, probemod, probefunc,
probename,arg0,arg1,arg2,arg3,arg4,arg5);
       i=i+1;
}

2.授权限
chmod 755 dtrace.d

3.执行dtrace命令生成跟踪日志
./dtrace.d -x switchrate=1hz -b 32m 2416 > dtracecbc.log --用这条命令加大了缓存,避免丢失日志

4.显示主要dtrace部分日志,在dtracecbc.log中搜索latch地址:3A4282A90

CPU     ID                    FUNCTION:NAME
 --逻辑读开始
 1  63919                    kcbgtcr:entry i=592
PID::entry:==pid2416:oracle:kcbgtcr:entry fffffd7ffc98bc00 0 2fe 0
23dede0 fffffd7fffdfa7a0
 --获取CBC Latch
 1 128720                  sskgslcas:entry i=593
PID::entry:==pid2416:oracle:sskgslcas:entry 3a4282a90 0 1 0 0
3a4c953d0          
 1  60714                     ktrexf:entry i=594
PID::entry:==pid2416:oracle:ktrexf:entry fffffd7fffdfa7a0 d7fcd60 0
15392235540 1fe8 23dc9f0
 1  64185                     kcbzgs:entry i=595 PID::entry:==pid2416:oracle:kcbzgs:entry 1 d7fcd60 0 0 0 23dc9f0
 1  53939           kssadf_numa_intl:entry i=596
PID::entry:==pid2416:oracle:kssadf_numa_intl:entry 23 3a4145900
3a487d9e8 0 0 1d
 --根据DBA找到BH(Buffer Header)加Buffer Pin
 1 128720                  sskgslcas:entry i=597 PID::entry:==pid2416:oracle:sskgslcas:entry 3957f6280 0 1 0 3957f6238 3957f6238
 --加完Buffer Pin马上释放CBC Latch
 1 128723                 sskgsldecr:entry i=598
PID::entry:==pid2416:oracle:sskgsldecr:entry 3a4282a90 1 1 0 1
2000000000000000          
 1  63951                     kcbcge:entry i=599
PID::entry:==pid2416:oracle:kcbcge:entry fffffd7ffc98bc00 0 77 0
fffffd7ffc98b7dc 0
 1  64116                  kcbds2pbh:entry i=600
PID::entry:==pid2416:oracle:kcbds2pbh:entry fffffd7ffc98bc00 0 77 0
fffffd7ffc98b7dc 0
 1  60179                     ktcckv:entry i=601
PID::entry:==pid2416:oracle:ktcckv:entry fffffd7ffc98bc00
fffffd7ffc98b7d4 77 0 3a3c935f0 0
 1 104774                     kafger:entry i=602
PID::entry:==pid2416:oracle:kafger:entry 39572e064 fffffd7fffdfb200
39d84e4f0 2 1 1
 1  83919                     kpofcr:entry i=603
PID::entry:==pid2416:oracle:kpofcr:entry fffffd7fffdfb4b0 1 39d84e4f0 2
4c30d40 3a4fd3790
 1 124023                     ttcrxh:entry i=604
PID::entry:==pid2416:oracle:ttcrxh:entry d8055e8 d7f58f0
fffffd7fffdfafe0 48 214 1
 1 209006                     memcpy:entry i=605
PID::entry:==pid2416:libc.so.1:memcpy:entry ddfa329 fffffd7fffdfafe0 30
48 ddfa359 d7f5a00
 1 209006                     memcpy:entry i=606 PID::entry:==pid2416:libc.so.1:memcpy:entry ddfa35b 39572fff5 2 2 2 d7f5a00
 1 123964                     ttcc2u:entry i=607 PID::entry:==pid2416:oracle:ttcc2u:entry d8055e8 d7f58f0 39572fff8 4 1 1
 1 209006                     memcpy:entry i=608
PID::entry:==pid2416:libc.so.1:memcpy:entry ddfa35e 39572fff8 4 852
d7f5a00 d7f5a00
 1  61112            ktsmg_max_query:entry i=609 PID::entry:==pid2416:oracle:ktsmg_max_query:entry 0 0 39572fffc 0 d805250 2
 1 211309                  gethrtime:entry i=610
PID::entry:==pid2416:libc.so.1:gethrtime:entry 92d 1a 39572fffc 8
3a4447d80 39de97dc8
 1 128314                    slcpums:entry i=611
PID::entry:==pid2416:oracle:slcpums:entry d805218 1a 494b3f016 8
3a443a460 39c253698
 1 211401                      times:entry i=612
PID::entry:==pid2416:libc.so.1:times:entry fffffd7fffdfb240 1a 494b3f016
8 3a443a460 39c253698
 1 131260     kglHandleInvalidations:entry i=613
PID::entry:==pid2416:oracle:kglHandleInvalidations:entry d8055e8
39df04bb0 0 8 d7f1a10 39c2d1140
 1 131261             kglHandleLoads:entry i=614
PID::entry:==pid2416:oracle:kglHandleLoads:entry d8055e8 39df04bb0 0 8
d7f1a10 39c2d1140
 1  91756                kksGetStats:entry i=615
PID::entry:==pid2416:oracle:kksGetStats:entry 39d738198 39df04bb0 0 8
d7f1a10 39c2d1140
 1  72794            kews_sqlcol_end:entry i=616
PID::entry:==pid2416:oracle:kews_sqlcol_end:entry 3a4fd2210
fffffd7ffc9e1ad8 39d737e88 70 1 1
 1 110094                  qecrlssub:entry i=617
PID::entry:==pid2416:oracle:qecrlssub:entry 39d84ed10 fffffd7ffc9e1ad8 9
0 fffffd7ffc98ac58 0
 1 108487               qertbRelease:entry i=618
PID::entry:==pid2416:oracle:qertbRelease:entry 39d84dea8
fffffd7ffc98bae0 9 0 4c0 dbb56b0
 1 104779                     kafcpy:entry i=619 PID::entry:==pid2416:oracle:kafcpy:entry 39d84e4f0 2 9 0 fffffd7ffc987430 20
 --访问Buffer开始fetch数据
 1 209006                     memcpy:entry i=620
PID::entry:==pid2416:libc.so.1:memcpy:entry fffffd7ffc9f49f8 39572fff8 4
0 30 20              
 1 209006                     memcpy:entry i=621
PID::entry:==pid2416:libc.so.1:memcpy:entry fffffd7ffc9f49e0 39572fff5 2
1 30 20            
 1  63927                   kcbipnns:entry i=622
PID::entry:==pid2416:oracle:kcbipnns:entry fffffd7ffc98bc00 39572fff5
39572fff7 0 fffffd7ffc98bbe8 2c1

【转】Cache Buffer Chain 第二篇的更多相关文章

  1. 【转】cache buffer chain 第一篇

    文章转自:http://www.jydba.net/cache-buffer-chain/ buffer cache的管理有两个重要的数据结构: hash bucket和cache buffer ch ...

  2. 【原】Cache Buffer Chain 第四篇

    作者:david_zhang@sh [转载时请以超链接形式标明文章] 链接:http://www.cnblogs.com/david-zhang-index/p/3873357.html [测试1]低 ...

  3. 【转】Cache Buffer Chain 第三篇

    文章转自:http://oracle.chinaitlab.com/induction/862509.html,文章前部分转载,后部分自己加上的. Oracle数据库只读模式的CACHE BUFFER ...

  4. [转帖]虚拟内存探究 -- 第二篇:Python 字节

    虚拟内存探究 -- 第二篇:Python 字节 http://blog.coderhuo.tech/2017/10/15/Virtual_Memory_python_bytes/ 是真看不懂哦     ...

  5. 【OpenGL】第二篇 Hello OpenGL

    ---------------------------------------------------------------------------------------------------- ...

  6. lnux内核的malloc实现(Oracle的cache buffer影子)

    lnux内核的malloc实现(Oracle的cache buffer影子) 本文原创为freas_1990,转载请标明出处:http://blog.csdn.net/freas_1990/artic ...

  7. Python人工智能第二篇

    Python人工智能之路 - 第二篇 : 现成的技术   预备资料: 1.FFmpeg: 链接:https://pan.baidu.com/s/1jonSAa_TG2XuaJEy3iTmHg 密码:w ...

  8. ElasticSearch入门 第二篇:集群配置

    这是ElasticSearch 2.4 版本系列的第二篇: ElasticSearch入门 第一篇:Windows下安装ElasticSearch ElasticSearch入门 第二篇:集群配置 E ...

  9. SDWebImage源码阅读-第二篇

    一  SDWebImageManager的downloadImageWithURL的方法 上一篇,我们刚开了个头,分析了一下开始加载图片之前如何取消其他正在下载的任务,接着,我们回到 - (void) ...

随机推荐

  1. nagios插件之登陆SBC监控电话数

    运行:sbc_calls_status_new auto_ssh_sbc_10_17.sh | auto_ssh_sbc_11_17.sh vi sbc_calls_status_new.c #inc ...

  2. 图像处理算法2——Otsu最佳阈值分割法http://blog.csdn.net/xiaqunfeng123/article/details/17121195

    http://blog.csdn.net/xiaqunfeng123/article/details/17121195Otsu法是1979年由日本大津提出的.该方法在类间方差最大的情况下是最佳的,即统 ...

  3. OpenCV for Python 学习笔记 二

    今天主要看了OpenCV中的事件以及回调函数,这么说可能不准确,主要是下面这两个函数(OpenCV中还有很多这些函数,可以在 http://docs.opencv.org/trunk/modules/ ...

  4. c++ builder 版CreateAnonymousThread用法

    万一老师的<如今, Delphi 的多线程已经很易用了!>讲到了TThread.CreateAnonymousThread用法 如今我来讲在c++ builder使用 CreateAnon ...

  5. Linux 下编译安装OpenCV(zhuanzai)

    http://www.cnblogs.com/emouse/archive/2013/02/22/2922940.html Cmake的安装 OpenCV 2.2以后版本需要使用Cmake生成make ...

  6. 对canvas arc()中counterclockwise参数的一些误解

    一直没有很细心地去研究CanvasRenderingContext2D对象的arc方法,对它的认识比较模糊,导致犯了一些错误,特发此文,以纠正之前的错误理解. arc()方法定义如下: arc() 方 ...

  7. 通过Pojo对象 field 属性加注解实现格式校验,极大的降低代码量

    近期做一个接口.接受外系统的报文,通过XStream转换成java对象以后.须要对当中的字段做格式校验. 要求例如以下: 传统的方式是硬编码校验.可是对于field非常多的情况.代码量暴增.easy出 ...

  8. sublime 快捷键 汇总--长期

    Ctrl+P 输入当前项目中的文件名,快速搜索文件 Ctrl+G 输入数字跳转到该行代码 Ctrl+R 输入关键字,查找文件中的函数名 Ctrl+: 输入关键字,查找文件中的变量名.属性名等 Ctrl ...

  9. 【BZOJ1043】[HAOI2008]下落的圆盘 几何

    [BZOJ1043][HAOI2008]下落的圆盘 Description 有n个圆盘从天而降,后面落下的可以盖住前面的.求最后形成的封闭区域的周长.看下面这副图, 所有的红色线条的总长度即为所求.  ...

  10. spring 集成 mybatis 后数据源初始化失败问题分析

    问题背景: 项目使用spring,springmvc框架,后边需操作关系数据库,选择了mybatis + durid,集成mybatis后,项目一直启动失败.错误的原因是dataSource初始化的时 ...