zoukankan      html  css  js  c++  java
  • Oracle 堵塞(blocking blocked)

       堵塞是DBA常常碰到的情形,尤其是不良的应用程序设计的堵塞将导致性能严重下降直至数据库崩溃。

    对DBA而言,有必要知道怎样定位到当前系统有哪些堵塞,究竟谁是堵塞者,谁是被堵塞者。本文对此给出了描写叙述并做了相关演示。

     

    1、堵塞及其类型
    a、什么是堵塞
       一个会话持有某个资源的锁,而还有一个会话在请求这个资源,就会出现堵塞(blocking)。也就是说新的会话会被挂起,直到持有锁的会话放弃锁定的资源。大多数情况下。在一个交互式应用中被严重堵塞,就可以表明应用逻辑有问题,这才是堵塞的根源。
    b、堵塞得类型
       数据库中有5条常见的DML语句可能会堵塞,即:INSERT、UPDATE、DELETE、MERGE 和SELECT FOR UPDATE。

     

    2、几种不同类型堵塞的处理办法
    a、INSERT堵塞主要是因为有一个带主键的表。或者表上有惟一的约束,在两个会话试图用相同的值插入一行时引发堵塞。多表通过引用完整性约束相互链接时,在其依赖的父表正在创建或删除期间,对子表的插入可能会堵塞。

    对于该类情形建议使用序列来生成主键/惟一列值。
    b、对于UPDATE、DELETE、MERGE 和SELECT FOR UPDATE堵塞,仅仅要有任一session使用这些操作已经锁定行,其余的必须处于等待状态。直到当前锁定行上的锁(排他锁)释放。

    对于该类情形。建议尽可能高速提交事务,或採用批量SQL方式提交。
    c、对于一个堵塞的SELECT FOR UPDATE,解决方式非常easy:仅仅需添加NOWAIT 子句。它就不会堵塞了。

     

    3、演示堵塞

    --更新表,注。提示符scott@CNMMBO表明用户为scott的session,username不同,session不同。

    scott@CNMMBO> update emp set sal=sal*1.1 where empno=7788; 1 row updated. scott@CNMMBO> @my_env SPID SID SERIAL# USERNAME PROGRAM ------------ ---------- ---------- --------------- ------------------------------------------------ 11205 1073 4642 robin oracle@SZDB (TNS V1-V3) --另起两个session更新相同的行,这两个session都会处于等待。直到第一个session提交或回滚 leshami@CNMMBO> update scott.emp set sal=sal+100 where empno=7788; goex_admin@CNMMBO> update scott.emp set sal=sal-50 where empno=7788; --以下在第一个session 查询堵塞情况 scott@CNMMBO> @blocker BLOCK_MSG BLOCK -------------------------------------------------- ---------- pts/5 ('1073,4642') is blocking 1067,10438 1 pts/5 ('1073,4642') is blocking 1065,4464 1 --上面的结果表明session 1073,4642 堵塞了后面的2个 --即session 1073,4642是堵塞者,后面2个session是被堵塞者 --Author : Leshami --Blog : http://blog.csdn.net/leshami --以下查询正在堵塞的session id,SQL语句以及被堵塞的时间 scott@CNMMBO> @blocking_session_detail.sql 'SID='||A.SID||'WAITCLASS='||A.WAIT_CLASS||'TIME='||A.SECONDS_IN_WAIT||CHR(10)||'QUERY='||B.SQL_TEXT ------------------------------------------------------------------------------------------------------- sid=1067 Wait Class=Application Time=5995 Query=update scott.emp set sal=sal+100 where empno=7788 sid=1065 Wait Class=Application Time=225 Query=update scott.emp set sal=sal-50 where empno=7788 --以下的查询堵塞时锁的持有情况 scott@CNMMBO> @request_lock_type USERNAME SID TY LMODE REQUEST ID1 ID2 ------------------------------ ---------- -- ----------- ----------- ---------- ---------- SCOTT 1073 TX Exclusive None 524319 27412 LESHAMI 1067 TX None Exclusive 524319 27412 GOEX_ADMIN 1065 TX None Exclusive 524319 27412 --能够看到LESHAMI。GOEX_ADMIN 2个用户都在请求524319/27412上的Exclusive锁,而此时已经被SCOTT加了Exclusive锁 --查询堵塞时锁的持有具体信息 scott@CNMMBO> @request_lock_detail SID USERNAME OSUSER TERMINAL OBJECT_NAME TY Lock Mode Req_Mode ---------- -------------------- --------------- ------------------------- -------------------- -- ----------- -------------------- 1065 GOEX_ADMIN robin pts/1 EMP TM Row Excl 1065 GOEX_ADMIN robin pts/1 Trans-524319 TX --Waiting-- Exclusive 1067 LESHAMI robin pts/0 EMP TM Row Excl 1067 LESHAMI robin pts/0 Trans-524319 TX --Waiting-- Exclusive 1073 SCOTT robin pts/5 EMP TM Row Excl 1073 SCOTT robin pts/5 Trans-524319 TX Exclusive

    文中涉及到的相关脚本下载:http://download.csdn.net/detail/robinson_0612/7607033    

    很多其它參考

    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语句运行计划

  • 相关阅读:
    线程池:
    C#:实现托盘
    Linux内核 TCP/IP、Socket参数调优
    redis配置文件redis.conf参数说明
    redis安装与参数说明
    巧用linux服务器的/dev/shm/,如果合理使用,可以避开磁盘IO不给力,提高网站访问速度。
    mkdir:批量创建文件夹
    linux下的shell运算(加、减、乘、除)
    Linux查看文件编码格式及文件编码转换
    解决vi/vim中粘贴会在行首多很多缩进和空格的问题
  • 原文地址:https://www.cnblogs.com/gavanwanggw/p/6878045.html
Copyright © 2011-2022 走看看