sql server 死鎖排查

来源:https://www.cnblogs.com/MrHSR/archive/2018/05/14/9034890.html
-Advertisement-
Play Games

記得以前客戶在使用軟體時,有偶發出現死鎖問題,因為發生的時間不確定,不好做問題的重現,當時解決問題有點棘手了。 現總結下查看死鎖的常用二種方式: 第一種是圖形化監聽: sqlserver -->工具--> sql server profiler 登錄後在跟蹤屬性中選擇如下圖: 監聽到的死鎖圖形如下圖 ...


 

記得以前客戶在使用軟體時,有偶發出現死鎖問題,因為發生的時間不確定,不好做問題的重現,當時解決問題有點棘手了。

現總結下查看死鎖的常用二種方式:

第一種是圖形化監聽:

  sqlserver -->工具--> sql server profiler   登錄後在跟蹤屬性中選擇如下圖:

   

   監聽到的死鎖圖形如下圖

    

   這裡的描述大致是:有二個進程 一個進程ID是96, 另一個ID是348.   系統自動kill 掉了進程ID:96,保留了進程ID:348 的事務Commit。

  上面死鎖是由於批量更新出現PAG範圍鎖, 雙方進程在同一分區索引資源上。ID96,348都請求想獲取更新鎖(U),各占排它鎖(x)不釋放,直到鎖超時。

第二種是使用日誌跟蹤(errorlog)

 以全局方式打開指定的跟蹤標記

    DBCC TRACEON(1222,-1)

    DBCC TRACEON(1204,-1) 

 使用  EXEC master..xp_readerrorlog 查看日誌。 由於記錄的死鎖信息太多,貼出幾個重點說下

Deadlock encountered .... Printing deadlock information
Wait-for graph
NULL
Node:1
PAGE: 7:1:6229275 CleanCnt:2 Mode:IX Flags: 0x3
Grant List 3:
Owner:0x00000004E99B7880 Mode: IX Flg:0x40 Ref:1 Life:02000000 SPID:219 ECID:0 XactLockInfo: 0x0000000575C7E970
SPID: 219 ECID: 0 Statement Type: UPDATE Line #: 84
Input Buf: Language Event: exec proc_PUB_StockDataImport
Requested by:
ResType:LockOwner Stype:'OR'Xdes:0x0000000C7A905D30 Mode: U SPID:64 BatchID:0 ECID:59 TaskProxy:(0x0000000E440AAFE0) Value:0x8d160240 Cost:(0/0)
NULL

Node:2
PAGE: 7:1:5692366 CleanCnt:2 Mode:U Flags: 0x3
Grant List 3:
Owner:0x0000000D12099B80 Mode: U Flg:0x40 Ref:0 Life:00000001 SPID:64 ECID:0 XactLockInfo: 0x000000136B4758F0
SPID: 64 ECID: 0 Statement Type: UPDATE Line #: 108
Input Buf: RPC Event: Proc [Database Id = 7 Object Id = 907150277]

-------- node:1 顯示的幾個關鍵信息:

 PAGE 7:1:6229275  (所在資料庫ID7, 1分區, 6229275行數)

 Mode: IX  鎖的模式  意向排它鎖

 SPID: 219  進程ID

 Event: exec proc_PUB_StockDataImport  執行的存儲過程名

-------node:2 顯示的幾個關鍵信息

RPC Event: Proc 遠程過程調用

 SPID: 64  進程ID

 

Victim Resource Owner:
ResType:LockOwner Stype:'OR'Xdes:0x0000000C7A905D30 Mode: U SPID:64 BatchID:0 ECID:59 TaskProxy:(0x0000000E440AAFE0) Value:0x8d160240 Cost:(0/0)
deadlock-list
deadlock victim=process956f4c8
process-list
process id=process956f4c8 taskpriority=0 logused=0 waitresource=PAGE: 7:1:6229275 waittime=2034 ownerId=2988267079 transactionname=UPDATE lasttranstarted=2018-04-19T13:54:00.360 XDES=0xc7a905d30 lockMode=U schedulerid=24 kpid=1308 status=suspended spid=64 sbid=0 ecid=59 priority=0 trancount=0 lastbatchstarted=2018-04-19T13:53:58.033 lastbatchcompleted=2018-04-19T13:53:58.033 clientapp=.Net SqlClient Data Provider hostname=VMSERVER76 hostpid=16328 isolationlevel=read committed (2) xactid=2988267079 currentdb=7 lockTimeout=4294967295 clientoption1=671088672 clientoption2=128056
executionStack
frame procname=Test.dbo.proc_CnofStock line=108 stmtstart=9068 stmtend=9336 sqlhandle=0x03000700c503123601ba25019ca800000100000000000000
update dbo.pub_stock
set UpdateTime=GETDATE()
from pub_stock a
join PUB_PlatfromStocktemp b on a.GUID=b.StockGuid

從上面的信息能看到kill 掉的是進程id是process956f4c8, 進程spid=64,lockMode=U 獲取更新鎖, executionStack 執行的堆信息

 

總結   避免死鎖的解決方法

         按同一順序訪問對象。

        優化索引,避免全表掃描,減少鎖的申請數目.

        避免事務中的用戶交互。

        使用基於行版本控制的隔離級別。

         將事務預設隔離級別的已提交讀改成快照

         SET TRANSACTION ISOLATION LEVEL SNAPSHOT

       使用nolock去掉共用鎖,但死鎖發生在u鎖或x鎖上,則nolock不起作用

       升級鎖顆粒度(頁鎖,表鎖), 以阻塞還代替死鎖

 

  

   

  

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1、解壓到想要安裝的位置,創建my.ini文件 my.ini的內容如下 2、用管理員許可權打開cmd命令行 3、切換到安裝目錄的bin文件夾目錄下,初始化data文件夾,因為解壓後的目錄里是沒有data文件夾的,不用手動創建 ——初始化的命令如下 ——安裝MySQL服務 ——啟動MySql服務 4、修 ...
  • 一、 視圖 二、 觸發器 三、 事務 四、 存儲過程 五、 函數 六、 流程式控制制 一 、視圖 視圖是一個虛擬表(非真實存在),其本質是【根據SQL語句獲取動態的數據集,併為其命名】,用戶使用時只需使用【名稱】即可獲取結果集,可以將該結果集當做表來使用。 使用視圖我們可以把查詢過程中的臨時表摘出來,用 ...
  • 在8之前的版本中,對於全局變數的修改,其只會影響其記憶體值,而不會持久化到配置文件中。資料庫重啟,又會恢覆成修改前的值。從8開始,可通過SET PERSIST命令將全局變數的修改持久化到配置文件中。 試舉一例 全局變數的修改會保存在兩處, 1. 數據目錄下mysqld-auto.cnf文件, 註意,不 ...
  • 查詢的基本語法 from關鍵字後面寫表名,表示數據來源於是這張表 select後面寫表中的列名,如果是*表示在結果中顯示表中所有列 在select後面的列名部分,可以使用as為列起別名,這個別名出現在結果集中 如果要查詢多個列,之間使用逗號分隔 消除重覆行 在select後面列前使用distinct ...
  • 1.大小寫轉換快捷鍵:Ctrl+Shift+U 轉為大寫 ,Ctrl+Shift+L 轉為小寫 ... ...
  • Oracle: create table zjhis.mz_zdxx_zl as select a.sfsb, wm_concat(a.zdmc) as 診斷 from zjhis.mz_zdxx a group by a.sfsb 直接可以使用 wm_concat 函數 SQl SERVER : ...
  • select * from(select row_number() over(partition by IDCARD order by DATATM desc) as rownum,* from (SELECT * FROM TABLENAME)as H1 ) as H where H.rownum ...
  • 一、在控制面板,卸載MySQL的所有組件 控制面板——》所有控制面板項——》程式和功能,卸載所有和MySQL有關的程式 二、找到你的MysQL安裝路徑,看還有沒有和MySQL有關的文件夾,全刪 如果安裝在C盤,檢查一下C:\Program Files (x86)和C:\Program Files 這 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...