RAC环境下的堵塞不同于单实例情形,由于我们须要考虑到位于不同实例的session。也就是说之前查询的v$session,v$lock对应的应变化为全局范围来查找。本文提供了2个查询脚本,并给出实例演示那些session为堵塞者。哪些为被堵塞者。有关堵塞的概念以及单实例环境下的堵塞请參考:Oracle 堵塞(blocking blocked)

1、演示环境

scott@DEVDB> select * from v$version where rownum<2;

BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - 64bit Production --在scott session中公布SQL语句,并未提交
scott@DEVDB> begin
2 update emp set sal=sal+100 where empno=7788;
3 update dept set dname='DBA' where deptno=10;
4 end;
5 / PL/SQL procedure successfully completed. --在leshami session中更新emp对象
leshami@DEVDB> update scott.emp set sal=sal-200 where empno=7788; --在usr1 session中更新emp对象
usr1@DEVDB> update scott.dept set dname='DEV' where deptno=10;

2、寻找堵塞

scott@DEVDB> @block_session_rac

USER_STATUS     SID_SERIAL      CONN_INSTANCE     SID PROGRAM                        OSUSER  MACHINE         LOCK_TYPE       LOCK_MODE        CTIME OBJECT_NAME
--------------- --------------- ---------------- ---- ------------------------------ ------- --------------- --------------- ----------- ---------- -------------------------
Blocking -> '20,1545' devdb1 20 sqlplus@Linux-01 (TNS V1-V3) oracle Linux-01 Transaction Exclusive 666 DEPT
Blocking -> '20,1545' devdb1 20 sqlplus@Linux-01 (TNS V1-V3) oracle Linux-01 Transaction Exclusive 666 EMP
Waiting '49,1007' devdb1 49 sqlplus@Linux-01 (TNS V1-V3) oracle Linux-01 Transaction None 618 EMP
Waiting '933,11691' devdb2 933 sqlplus@Linux-02 (TNS V1-V3) oracle Linux-02 Transaction None 558 DEPT --通过上述脚本我们能够看到session '20,1545' 锁住了对象DEPT以及EMP。而此时session '49,1007'与'933,11691'处于等待状态。 --以下是另外的一种方式来获取堵塞的情形
scott@DEVDB> @block_session_rac2 BLOCKING_STATUS
----------------------------------------------------------------------------------------------------------------------------
SCOTT@Linux-01 ( INST=1 SID=20 Serail#=1545 ) IS BLOCKING USR1@Linux-02 ( INST=2 SID=933 Serial#=11691 )
SCOTT@Linux-01 ( INST=1 SID=20 Serail#=1545 ) IS BLOCKING LESHAMI@Linux-01 ( INST=1 SID=49 Serial#=1007 ) --Author : Leshami
--Blog : http://blog.csdn.net/leshami

3、演示中用到的脚本

[oracle@Linux-01 ~]$ more block_session_rac.sql
set linesize 180
col user_status format a15
col sid_serial format a15
col program format a30 wrapped
col machine format a15 wrapped
col osuser format a15 wrapped
col conn_instance format a15
col object_name format a25 wrapped
SELECT DECODE (l.block, 0, 'Waiting', 'Blocking ->') user_status,
CHR (39) || s.sid || ',' || s.serial# || CHR (39) sid_serial,
(SELECT instance_name
FROM gv$instance
WHERE inst_id = l.inst_id)
conn_instance,
s.sid,
s.program,
s.osuser,
s.machine,
DECODE (l.TYPE,
'RT', 'Redo Log Buffer',
'TD', 'Dictionary',
'TM', 'DML',
'TS', 'Temp Segments',
'TX', 'Transaction',
'UL', 'User',
'RW', 'Row Wait',
l.TYPE)
lock_type--,id1
--,id2
,
DECODE (l.lmode,
0, 'None',
1, 'Null',
2, 'Row Share',
3, 'Row Excl.',
4, 'Share',
5, 'S/Row Excl.',
6, 'Exclusive',
LTRIM (TO_CHAR (lmode, '990')))
lock_mode,
ctime--,DECODE(l.BLOCK, 0, 'Not Blocking', 1, 'Blocking', 2, 'Global') lock_status
,
object_name
FROM gv$lock l
JOIN gv$session s ON (l.inst_id = s.inst_id AND l.sid = s.sid)
JOIN gv$locked_object o
ON (o.inst_id = s.inst_id AND s.sid = o.session_id)
JOIN dba_objects d ON (d.object_id = o.object_id)
WHERE (l.id1, l.id2, l.TYPE) IN (SELECT id1, id2, TYPE
FROM gv$lock
WHERE request > 0)
ORDER BY id1, id2, ctime DESC; [oracle@Linux-01 ~]$ more block_session_rac2.sql
SELECT DISTINCT
s1.username
|| '@'
|| s1.machine
|| ' ( INST='
|| s1.inst_id
|| ' SID='
|| s1.sid
|| ' Serail#='
|| s1.serial#
|| ' ) IS BLOCKING '
|| s2.username
|| '@'
|| s2.machine
|| ' ( INST='
|| s2.inst_id
|| ' SID='
|| s2.sid
|| ' Serial#='
|| s2.serial#
|| ' ) '
AS blocking_status
FROM gv$lock l1,
gv$session s1,
gv$lock l2,
gv$session s2
WHERE s1.sid = l1.sid
AND s2.sid = l2.sid
AND s1.inst_id = l1.inst_id
AND s2.inst_id = l2.inst_id
AND l1.block > 0
AND l2.request > 0
AND l1.id1 = l2.id1
AND l1.id2 = l2.id2;

很多其它參考

DML Error Logging 特性

PL/SQL --> 游标

PL/SQL --> 隐式游标(SQL%FOUND)

批量SQL之 FORALL 语句

批量SQL之 BULK COLLECT 子句

PL/SQL 集合的初始化与赋值

PL/SQL 联合数组与嵌套表
PL/SQL 变长数组
PL/SQL --> PL/SQL记录

SQL tuning 步骤

高效SQL语句必杀技

父游标、子游标及共享游标

绑定变量及其优缺点

dbms_xplan之display_cursor函数的使用

dbms_xplan之display函数的使用

运行计划中各字段各模块描写叙述

使用 EXPLAIN PLAN 获取SQL语句运行计划

最新文章

  1. [Asp.net 5] Configuration-新一代的配置文件
  2. 自定义JS控件-简单示例
  3. Apache 80无法启动
  4. LL谱面分析和难度标定
  5. (转)如何将本地git仓库上传到GitHub中托管+实践心得
  6. include使用中注意的问题
  7. ural 1249. Ancient Necropolis
  8. 汉诺塔算法详解之C++
  9. CI调试
  10. 在AX4.0中使用C#脚本的实现
  11. SQL Server 2008 的gis函数
  12. UVA 10510 Cactus
  13. Jordan Lecture Note-2: Maximal Margin Classifier
  14. github 查看单个文件的历史记录命令
  15. ACM-简单题之Ignatius and the Princess II——hdu1027
  16. 深入解析FileInputStream和FileOutputStream
  17. cp复制文件到多个目录下及强制覆盖
  18. 【前端单元测试入门01】Mocha与chai
  19. T-SQL 簡易小數處理
  20. SQL Server 关于 Table 字典数据的查询SQL

热门文章

  1. 【BZOJ 2878】 2878: [Noi2012]迷失游乐园 (环套树、树形概率DP)
  2. POJ2068 Nim 博弈论 dp
  3. Android Studio自动化快速实现Parcelable接口序列化
  4. Problem F: 零起点学算法85——数组中插入一个数
  5. (转)DLL中导出函数的两种方式(dllexport与.def文件)
  6. c++中const使用详解
  7. 用 Jenkins + .netcore 2.0 构建
  8. 【spring colud】spring cloud微服务项目搭建【spring boot2.0】
  9. OCP升级(3.7 -&gt;3.9)
  10. linux安装ping