MySQL 數據庫死鎖


數據庫死鎖

  • 死鎖的解決辦法(1)
    1. 執行下面SQL,先查看哪些表被鎖住了:

      select b.owner,b.object_name,a.session_id,a.locked_mode
      from v$locked_object a,dba_objects b
      where b.object_id = a.object_id;
      
    2. 查處引起死鎖的會話

      select b.username,b.sid,b.serial#,logon_time 
      from vlocked_object a,vsession b
      where a.session_id = b.sid order by b.logon_time;
      -- 這里會列出SID
      
    3. 查出SID和SERIAL#:

      查V$SESSION視圖:

      SELECT SID,SERIAL#,PADDR FROM V$SESSION WHERE SID='剛才查到的SID'; 
      -- 這一步將得到PADDR 
      
    4. 查V$PROCESS視圖:

      SELECT SPID FROM V$PROCESS WHERE ADDR='剛才查到的PADDR'; 
      -- 這一步得到SPID 
      
    5. 殺死進程

      • 在數據庫中,殺掉ORACLE進程:

        ALTER SYSTEM KILL SESSION '查出的SID,查出的SERIAL#'; 
        
      • 如果在ORACLE中不能殺死進程,我們只能到操作系統中,使用操作系統命令殺死進程

        KILL -9  “剛才查出的SPID”
        

        在WINDOWS平台,可以是偶那個orakill。

  • 也可以根據對象模糊匹配直接查詢死鎖的session信息
    SELECT vl.session_id || ',' || b.serial#, ao.object_name, b.*
    FROM vlocked_object vl, all_objects ao, vsession b
    WHERE vl.object_id = ao.object_id
        AND vl.session_id = b.sid
        AND b.status = 'ACTIVE'          --session狀態根據需要添加
        AND ao.object_name LIKE 'object_name'; 
    
    在數據庫中,殺掉進程:
    ALTER SYSTEM KILL SESSION '查出的SID, 查出的SERIAL#'; 
    
  • 死鎖的解決辦法(2)
    1. 查詢死鎖的對象:

      select username,lockwait,status,machine,program from v$session where sid in
       (select session_id from v$locked_object);
      
    2. 查詢死鎖語句:

       select sql_text from v$sql where hash_value in 
       (select sql_hash_value from v$session where sid in
       (select session_id from v$locked_object));
      
      
      SELECT s.lockwait,s.status,s.username,l.OBJECT_ID,l.SESSION_ID,s.SERIAL#,l.ORACLE_USERNAME,l.OS_USER_NAME,l.PROCESS 
      FROM VLOCKED_OBJECT l,VSESSION S 
      WHERE l.SESSION_ID=S.SID and s.STATUS='ACT\IVE';
      
      
      alter system kill session '25,16823' IMMEDIATE;
      alter system kill session ‘sid,serial#’ IMMEDIATE;
      


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM