[20190415]10g下那些latch是共享的.txt

http://andreynikolaev.wordpress.com/2010/11/23/shared-latches-by-oracle-version/

--//oracle并没有文档准确说明那些latch是支持共享,作者的链接通过使用orderbug手工调用kslgetsl()函数(10g)或者kslgetsl_w()函
--//数(11g),确定那些latch支持共享模式.我仅仅重复测试看看.

1.环境:
SYS@test> @ &r/ver1
PORT_STRING                    VERSION        BANNER
------------------------------ -------------- ----------------------------------------------------------------
x86_64/Linux 2.4.xx            10.2.0.4.0     Oracle Database 10g Enterprise Edition Release 10.2.0.4.0 - 64bi

2.建立测试脚本:
--//drop table shared_latches purge;
create table shared_latches(
  version varchar2(50),   /* Oracle version */
  latch# number,          /* latch# */
  name   varchar2(200),   /* ltach name */
  shared varchar2(1)      /* if 'Y' then latch is shared  */
);
--//建立表shared_latches.

spool list_shared_latches.sh
select 'sqlplus /nolog @is_latch_shared 0x'||addr||' '||latch#||' "'||translate(name,'''',' ')||'"'
   from v$latch_parent;
spool off
--//获得latch list.仅仅测试latch parent就ok了.适当编辑整理脚本.

$ cat is_latch_shared.sql
/*
     This file is part of demos for "Contemporary Latch Internals" seminar v.24.08.2010
     Copyright:   (c) Andrey S. Nikolaev (Andrey.Nikolaev@rdtex.ru) RDTEX
     http://AndreyNikolaev.wordpress.com
     for 32bit Oracle 10g and above
*/
connect / as sysdba
set verify off
WHENEVER SQLERROR EXIT;
set pagesize 0

alter session set max_dump_file_size=0;
/*
   before 11g shared latch get function was named kslgetsl()
   in 11g - kslgetsl_w()
*/
col shared_latch_function new_value shared_latch_function
var db_v varchar2(100);
var db_comp varchar2(100);
begin dbms_utility.db_version(:db_v,:db_comp); end;
/
select decode(sign(replace(:db_v,'.','')-110000),1,'kslgetsl_w', 'kslgetsl') shared_latch_function from dual;
--//11g use kslgetsl_w,other use kslgetsl.

oradebug setmypid
/* try to get latch as shared in S mode */
oradebug call &shared_latch_function &1 1 2 3 8
/* if ORA-00600: [545] was raised in previous statement then latch was exclusive.  The error terminates the script */
/* free the latch */
oradebug call kslfre &1
/* if we are here, the latch was shared */
insert into shared_latches(version,latch#,name,shared) select version,latch#,name,'Y' from v$latch,v$instance where latch#=&2;
commit;
exit

--//说明:作者利用oradebug调用报错,后面的插入语句不会执行,来完整获得那些shared latch的列表.

3.执行:
$ . list_shared_latches.sh > /dev/null
--//略.

4.结果:
SYS@test> select * from shared_latches;
VERSION        LATCH# NAME                                     S
---------- ---------- ---------------------------------------- -
10.2.0.4.0          7 session idle bit                         Y
10.2.0.4.0          8 client/application info                  Y
10.2.0.4.0         35 resmgr group change latch                Y
10.2.0.4.0         36 channel handle pool latch                Y
10.2.0.4.0         37 channel operations parent latch          Y
10.2.0.4.0         38 message pool operations parent latch     Y
10.2.0.4.0         51 SGA mapping latch                        Y
10.2.0.4.0         52 active service list                      Y
10.2.0.4.0         97 name-service namespace bucket            Y
10.2.0.4.0        101 gcs remastering latch                    Y
10.2.0.4.0        102 gcs partitioned table hash               Y
10.2.0.4.0        103 gcs pcm hashed value bucket hash         Y
10.2.0.4.0        106 recovery domain hash list                Y
10.2.0.4.0        109 Memory Management Latch                  Y
10.2.0.4.0        118 buffer pool                              Y
10.2.0.4.0        122 cache buffers chains                     Y
10.2.0.4.0        131 object queue header operation            Y
10.2.0.4.0        150 KCL gc element parent latch              Y
10.2.0.4.0        193 In memory undo latch                     Y
10.2.0.4.0        194 KTF sga latch                            Y
10.2.0.4.0        196 Change Notification Hash table latch     Y
10.2.0.4.0        204 global KZLD latch for mem in SGA         Y
10.2.0.4.0        207 Policy Refresh Latch                     Y
10.2.0.4.0        208 Policy Hash Table Latch                  Y
10.2.0.4.0        209 OLS label cache                          Y
10.2.0.4.0        210 instance information                     Y
10.2.0.4.0        211 policy information                       Y
10.2.0.4.0        212 global ctx hash table latch              Y
10.2.0.4.0        221 library cache hash chains                Y
10.2.0.4.0        229 resmgr:active threads                    Y
10.2.0.4.0        238 resmgr:plan CPU method                   Y
10.2.0.4.0        244 Shared B-Tree                            Y
10.2.0.4.0        245 Memory Queue                             Y
10.2.0.4.0        246 Memory Queue Subscriber                  Y
10.2.0.4.0        271 JOX SGA heap latch                       Y
10.2.0.4.0        284 hash table column usage latch            Y
10.2.0.4.0        291 compile environment latch                Y
10.2.0.4.0        314 KWQP Prop Status                         Y
10.2.0.4.0        315 AQ Propagation Scheduling Proc Table     Y
10.2.0.4.0        316 AQ Propagation Scheduling System Load    Y
10.2.0.4.0        319 rules engine rule set statistics         Y
10.2.0.4.0        320 rules engine rule statistics             Y
10.2.0.4.0        325 kwqbsn:qsga                              Y
10.2.0.4.0        327 bufq statistics                          Y
10.2.0.4.0        329 queue sender's info. latch               Y
10.2.0.4.0        330 bq:time manger info latch                Y
10.2.0.4.0        333 KWQMN job cache list latch               Y
10.2.0.4.0        334 KWQMN to-be-Stopped Buffer list Latch    Y
10.2.0.4.0        392 JS Sh mem access                         Y
10.2.0.4.0        393 PL/SQL warning settings                  Y
50 rows selected.

--//我导入作者的测试结果在链接https://andreynikolaev.wordpress.com/上可以找到.
--//https://andreynikolaev.wordpress.com/summary-tables/shared_latches-ctl/
--//10.2.0.4.0结果如下:
SYS@book> select count(*) from  scott.shared_latches where version='10.2.0.4.0';
  COUNT(*)
----------
        51

--//相差1个.

SYS@192.168.100.33:1521/test> @ ver1
PORT_STRING                    VERSION        BANNER
------------------------------ -------------- ----------------------------------------------------------------
x86_64/Linux 2.4.xx            10.2.0.4.0     Oracle Database 10g Enterprise Edition Release 10.2.0.4.0 - 64bi

SYS@192.168.100.33:1521/test> @ laddr.sql 'parameter table allocation management'
ADDR             NAME
---------------- ----------------------------------------
0000000060009298 parameter table allocation management

SYS@book> select * from scott.shared_latches where version='10.2.0.4.0' minus select * from sys.shared_latches@test033;
VERSION        LATCH# NAME                                     S
---------- ---------- ---------------------------------------- -
10.2.0.4.0         15 parameter table allocation management    Y

--//我手工执行发现报错,
SYS@192.168.100.33:1521/test> oradebug setmypid
Statement processed.

SYS@192.168.100.33:1521/test> oradebug call kslgetsl 0x0000000060009298 1 2 3 8
ORA-00600: internal error code, arguments: [545], [0x060009298], [15], [8], [], [], [], []

[20190415]10g下那些latch是共享的.txt的更多相关文章

  1. [20190415]11g下那些latch是共享的.txt

    [20190415]11g下那些latch是共享的.txt http://andreynikolaev.wordpress.com/2010/11/23/shared-latches-by-oracl ...

  2. [20190416]11g下那些latch是Exclusive的.txt

    [20190416]11g下那些latch是Exclusive的.txt --//昨天测试了11g下那些latch是共享的,链接:--//是否反过来剩下的都是Exclusive的.继续测试: 1.环境 ...

  3. oracle 10g下范围分区扫描的几种方式

    oracle 10g下有几种扫描方式,注意最后一种扫描方式,当对分区的列进行计算时,会不走分区.这跟对索引列进行计算会导致无法用索引一样. --扫描单个分区  PARTITION RANGE SING ...

  4. Mac、Linux下两个Emacs共享一个配置文件

    Mac.Linux下两个Emacs共享一个配置文件 有些嵌入式的实验需要在Linux进行,就安装了RHEL6.4的虚拟机,下载并编译了Emacs. 在Linux的.emacs文件中加入以下语句,即可引 ...

  5. 阿里云服务器win2003下iis整合tomcat共享80端口

    阿里云服务器win2003下iis整合tomcat共享80端口 很多机器都用tomcat跟IIS部署不同网站.最近买了阿里云的服务器.于是也想玩一下.网上百度了很多方法.但是都有缺陷说的不是很清楚.通 ...

  6. [20190319]shared pool latch与library cache latch的简单探究.txt

    [20190319]shared pool latch与library cache latch的简单探究.txt --//昨天看Oracle DBA手记3:数据库性能优化与内部原理解析.pdf 电子书 ...

  7. [20190416]完善shared latch测试脚本2.txt

    [20190416]完善shared latch测试脚本2.txt --//昨天测试shared latch,链接:http://blog.itpub.net/267265/viewspace-264 ...

  8. [20190505]关于latch 一些统计信息.txt

    [20190505]关于latch 一些统计信息.txt --//我在两篇文章,提到一些latch的统计信息.链接如下:http://blog.itpub.net/267265/viewspace-2 ...

  9. [20190423]简单测试latch nowilling等待模式.txt

    [20190423]简单测试latch nowilling等待模式.txt --//我对这个问题的理解就是如果参数willing=0,表示无法获取该latch,直接退出,再寻找类似的latch.--/ ...

随机推荐

  1. [C#]批量修改文件后缀名

    代码: /// <summary> /// 修改文件后缀 /// </summary> /// <param name="extension"> ...

  2. linux系统安装cdcfordb2udb

    最近接触到db2数据库实时复制的解决方案InfoSphere CDC(Change Database Capture) .主要是通过读取源端的日志信息对目标端进行数据的增删改,从而尽量减少对源端资源的 ...

  3. SpringMVC+JWT+Swagger UI+RestFul

    前言: 其实很早就想写这篇文章了,因为我觉得这会对很多新手有指引作用,当初自己也是瞎子过河的摸索着过来的.目前后台开发比较流行的MVC框架中使用Spring MVC还是比较多的,当然还有Spring ...

  4. Hbase篇--HBase中一对多和多对多的表设计

    一.前述 今天分享一篇关于HBase的一对多和多对多的案例的分析. 二.具体案例 案例一.多对多    人员-角色   人员有多个角色  角色优先级   角色有多个人员   人员 删除添加角色   角 ...

  5. 运行PHP后台项目:xampp下载,安装,配置,运行PHP的web项目

    本来没有想着弄PHP,但是有同学叫我帮忙启动一下一个PHP写的后台.着实需要去学习一下. 想着安装xampp软件,一个集合了多个服务器,多个数据库,多个后台语言的管理软件. 一.xampp下载 二.安 ...

  6. 【Docker】(6)---Dockerfile文件

    springboot项目打包镜像中的Dockerfile文件 在讲Dockerfile文件之前应该先讲下maven的一个插件叫:dockerfile-maven-plugin.他们是组合一起用的 一. ...

  7. Python爬虫入门教程 24-100 微医挂号网医生数据抓取

    1. 写在前面 今天要抓取的一个网站叫做微医网站,地址为 https://www.guahao.com ,我们将通过python3爬虫抓取这个网址,然后数据存储到CSV里面,为后面的一些分析类的教程做 ...

  8. 精读《syntax-parser 源码》

    1. 引言 syntax-parser 是一个 JS 版语法解析器生成器,具有分词.语法树解析的能力. 通过两个例子介绍它的功能. 第一个例子是创建一个词法解析器 myLexer: import { ...

  9. RabbitMQ消息队列(六)-消息任务分发与消息ACK确认机制(.Net Core版)

    在前面一章介绍了在.Net Core中如何使用RabbitMQ,至此入门的的部分就完成了,我们内心中一定还有很多疑问:如果多个消费者消费同一个队列怎么办?如果这几个消费者分任务的权重不同怎么办?怎么把 ...

  10. tmux的详细讲解

    1. tmux介绍 tmux是一个优秀的终端复用软件,split窗口.可以在一个terminal下打开多个终端. 即使非正常掉线,也能保证当前的任务运行,这一点对于远程SSH访问特别有用,网络不好的情 ...