今天做测试,本来想测试library cache mutex X,结果意外发现11.2.0.4的一个bug 开始测试 1.查询要执行的SQL,是否有子游标,没有子游标
SYS@honor > select sql_id,child_number,sql_text from v$sql where sql_text like '%SELECT count(*) FROM t%'; SQL_ID CHILD_NUMBER SQL_TEXT ------------- ------------ -------------------------------------------------------------------------------- gxfdy6zpjvmtc 0 select sql_id,child_number,sql_text from v$sql where sql_text like '%SELECT coun
2.查询当前会话sid,session1执行相关存储过程
session1 > select * from v$mystat where statistic#=0; SID STATISTIC# VALUE ---------------------------------------- ---------------------------------------- ---------------------------------------- 49 0 0 session1 > DECLARE 2 a number; 3 v varchar2(20):='haha'; 4 BEGIN 5 FOR c IN 1..100000 6 LOOP 7 EXECUTE IMMEDIATE 'ALTER SESSION SET optimizer_index_cost_adj = 1'; EXECUTE IMMEDIATE 'SELECT count(*) FROM t' into a; 9 END LOOP; 10 END; 11 / PL/SQL procedure successfully completed.
2.查询当前会话sid,session2执行相关存储过程
session2 > select * from v$mystat where statistic#=0; SID STATISTIC# VALUE ---------------------------------------- ---------------------------------------- ---------- 58 0 ########## session2 > DECLARE 2 a number; 3 v varchar2(20):='haha'; 4 BEGIN 5 FOR c IN 1..100000 6 LOOP 7 EXECUTE IMMEDIATE 'ALTER SESSION SET optimizer_index_cost_adj = 2'; EXECUTE IMMEDIATE 'SELECT count(*) FROM t' into a; 9 END LOOP; 10 END; 11 / PL/SQL procedure successfully completed.
3.查询查询SQL子游标,发现有两个子游标
SYS@honor > select sql_id,child_number,sql_text from v$sql where sql_text like '%SELECT count(*) FROM t%'; SQL_ID CHILD_NUMBER SQL_TEXT ------------- ------------ -------------------------------------------------------------------------------- 5nbjnx26pn4rh 0 DECLARE a number; BEGIN FOR c IN 1..100000 LOOP EXECUTE IMMEDIAT 5tjqf7sx5dzmj 0 SELECT count(*) FROM t 5tjqf7sx5dzmj 1 SELECT count(*) FROM t f14srtthcadyq 0 DECLARE a number; v varchar2(20):='haha'; BEGIN FOR c IN 1..100000 L gxfdy6zpjvmtc 0 select sql_id,child_number,sql_text from v$sql where sql_text like '%SELECT coun
4.查询会话执行期间,等待事件,根据原理,两个存储过程执行过程中,会引发select语句子游标持有父游标的指向子游标的handle导致的cursor pin S wait on x争用,但是意外发现发生了latch free,经过查询latch类型,为parameter table management,并没有见过相关latch,去查Mos,发现命中bug,在12.2中修复,或者打补丁
SYS@honor1 > select sid,USERNAME,EVENT,sql_id,SQL_CHILD_NUMBER,p1,p2,p3,WAIT_CLASS,WAIT_TIME,BLOCKING_SESSION,BLOCKING_SESSION_STATUS from v$session where sid in ('49','58');
SID USERNAME EVENT SQL_ID SQL_CHILD_NUMBER P1 P2 P3 WAIT_CLASS WAIT_TIME BLOCKING_SESSION BLOCKING_SESSION_STATUS
---------- ----------- ------------------- ------------- ---------------- ---------- ---------- ---------- ----------- ---------- ---------------- -----------------------
49 LIBAI latch free 5nbjnx26pn4rh 0 1610665040 24 0 Other -1 NOT IN WAIT
58 LIBAI latch free 5tjqf7sx5dzmj 1 1610665040 24 0 Other -1 NOT IN WAIT
SYS@honor1 > select to_char('1610665040','xxxxxxxxxxxx') from dual;
TO_CHAR('1610
-------------
6000cc50
SYS@honor1 > select addr,latch#,hash,name from v$latch where addr like '%6000CC50%';
ADDR LATCH# HASH NAME
---------------- ---------------------------------------- ---------------------------------------- ----------------------------------------
000000006000CC50 24 722869772 parameter table management
5.bug说明:
| Session Waiting on 'Parameter Table Management' Latch (Doc ID 2271591.1) |
|
APPLIES TO:Oracle Database - Enterprise Edition - Version 11.2.0.4 to 12.1.0.2 [Release 11.2 to 12.1] Oracle Database Cloud Schema Service - Version N/A and later Oracle Database Exadata Cloud Machine - Version N/A and later Oracle Cloud Infrastructure - Database Service - Version N/A and later Oracle Database Exadata Express Cloud Service - Version N/A and later Information in this document applies to any platform.SYMPTOMSDatabase wait's for latch free ASH report shows following event values:Top Event P1/P2/P3 Values
Event % Event P1 Value, P2 Value, P3 Value % Activity Parameter 1 Parameter 2 Parameter 3 latch free 24.60 "1610670304","30","0" 24.52 address number tries <---------------- P2 is 30 Query from v$latchname shows latch to be 'parameter table management':
SQL> select name from v$latchname where latch#=30;
NAME ---------------------------------------------------------------- parameter table managementAnd it turns out the session is executing this pl/sql blockBEGIN EXECUTE IMMEDIATE 'alter session set current_schema = SCHEMA1' ; EXECUTE IMMEDIATE 'alter session set nls_date_format = ''MM/DD/YYYY''' ; DBMS_APPLICATION_INFO.SET_MODULE(:p1, NULL); DBMS_SESSION.SET_IDENTIFIER(:p2); DBMS_APPLICATION_INFO.SET_CLIENT_INFO(:p3); DBMS_APPLICATION_INFO.SET_ACTION(:p4); END; CAUSEThis is due to following bug:
Bug 20564072 : RELAX EXCLUSIVE GET ON PARAMETER TABLE MANAGEMENT LATCH FOR ALTER SESSION
This bug can be encountered if processes are contending for the "parameter table management" latch. SOLUTIONApply Patch 20564072 |
编辑推荐:
- parameter table management,11.2.0.4 Bug 2056407203-03
- 如果你的系统需要在一张很大的表上创建一个索引,你会考虑哪些因素?03-03
- oracle 12c 新增的LREG进程及其动态注册的过程03-03
- [20200117]ashtop脚本使用简介.txt03-03
- Poster stopped: message is larger than configured max size03-03
- Oracle数据块格式03-03
- oracle 12c 数据库实例监听无法注册问题一例03-03
- Bad check value found during backing up datafileBad check value found during bac03-03
相关推荐
-
雷神推出 MIX PRO II 迷你主机:基于 Ultra 200H,玻璃上盖 + ARGB 灯效
2 月 9 日消息,雷神 (THUNDEROBOT) 现已宣布推出基于英
-
制造商 Musnap 推出彩色墨水屏电纸书 Ocean C:支持手写笔、第三方安卓应用
2 月 10 日消息,制造商 Musnap 现已在海外推出一款 Oce
热文推荐
- parameter table management,11.2.0.4 Bug 20564072
- 如果你的系统需要在一张很大的表上创建一个索引,你会考虑哪些因素?
如果你的系统需要在一张很大的表上创建一个索引,你会考虑哪些因素?
26-03-03 - oracle 12c 新增的LREG进程及其动态注册的过程
oracle 12c 新增的LREG进程及其动态注册的过程
26-03-03 - Bad check value found during backing up datafileBad check value found during bac
- 体系_表空间和数据文件的管理
体系_表空间和数据文件的管理
26-03-03 - Oracle 扩充磁盘空间
Oracle 扩充磁盘空间
26-03-03 - Oracle修改instance_name、db_name、db_unique_name、service_names
- 数据库性能需求分析及评估模型
数据库性能需求分析及评估模型
26-03-03 - 了解这一点轻松解决Oracle数据库系统报错问题
了解这一点轻松解决Oracle数据库系统报错问题
26-03-03 - AUD: Audit Commit Delay exceeded, written a copy to OS Audit Trail
