亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > SQL Server > 正文

記一次公司倉庫數據庫服務器死鎖過程及解決辦法

2024-08-31 01:03:14
字體:
來源:轉載
供稿:網友

根據操作系統中的定義:死鎖是指在一組進程中的各個進程均占有不會釋放的資源,但因互相申請被其他進程所站用不會釋放的資源而處于的一種永久等待狀態。下面小編給大家分享一次公司倉庫數據庫服務器死鎖過程及解決辦法,需要的朋友一起看看吧

死鎖的四個必要條件:

互斥條件(Mutual exclusion):資源不能被共享,只能由一個進程使用。

請求與保持條件(Hold and wait):已經得到資源的進程可以再次申請新的資源。

非剝奪條件(No pre-emption):已經分配的資源不能從相應的進程中被強制地剝奪。

循環等待條件(Circular wait):系統中若干進程組成環路,該環路中每個進程都在等待相鄰進程正占用的資源。

倉庫揀貨卡死,排查了數據庫的很多地方,都沒有頭緒,最后到SQL Server 錯誤日志里查看,終于發現了蛛絲馬跡
 

  1. EXEC xp_readerrorlog 0,1,NULL,NULL,'2015-09-21','2015-10-10','DESC' 
  2. waiter id=process5c30e08 mode=U requestType=wait 
  3. waiter-list 
  4. owner id=process5c26988 mode=X 
  5. owner-list 
  6. keylock hobtid=72057597785604096 dbid=33 objectname=stoxxx.dbo.Orderxxx indexname=IX_PricingExpressProductCode_State id=lock17fa96980 mode=X associatedObjectId=72057597785604096 
  7. waiter id=process5c26988 mode=U requestType=wait 
  8. waiter-list 
  9. owner id=process5c30e08 mode=X 
  10. owner-list 
  11. keylock hobtid=72057597785604096 dbid=33 objectname=stoxxx.dbo.Orderxxx indexname=IX_PricingExpressProductCode_State id=lock87d69e780 mode=X associatedObjectId=72057597785604096 
  12. resource-list 
  13. (@OperateState money,@HandledByNewWms bit,@State int,@OrderOut int
  14. UPDATE [Orderxx] SET [OperateState] = @OperateState,[HandledByNewWms] = @HandledByNewWms WHERE (([Orderxxx].[State] = @State) And ([Orderxxx].[OrderOut] = @OrderOut) And ([Orderxxx].[PricingExpressProductCode] IN ('UKNIR')))  
  15. inputbuf 
  16. unknown  
  17. frame procname=unknown line=1 sqlhandle=0x000000000000000000000000000000000000000000000000 
  18. UPDATE [Orderxxx] SET [OperateState] = @OperateState,[HandledByNewWms] = @HandledByNewWms WHERE (([Orderxxx].[State] = @State) And ([Orderxxx].[OrderOut] = @OrderOut) And ([Orderxxx].[PricingExpressProductCode] IN ('UKNIR')))  
  19. frame procname=adhoc line=1 stmtstart=134 sqlhandle=0x020000009d376d18a17e7ea51289d8caa2fb4de65c976389 
  20. executionStack 
  21. process id=process5c30e08 taskpriority=0 logused=10320 waitresource=KEY: 33:72057597785604096 (112399c2054a) waittime=4813 ownerId=31578743038 transactionname=user_transaction lasttranstarted=2015-09-24T10:22:58.410 XDES=0x372e95950 lockMode=U schedulerid=17 kpid=8496 status=suspended spid=153 sbid=0 ecid=0 priority=0 trancount=2 lastbatchstarted=2015-09-24T10:22:58.540 lastbatchcompleted=2015-09-24T10:22:58.540 clientapp=.Net SqlClient Data Provider hostname=CK1-WIN-WEB02 hostpid=37992 loginname=ck1.biz isolationlevel=read committed (2) xactid=31578743038 currentdb=33 lockTimeout=4294967295 clientoption1=671088672 clientoption2=128056 
  22. (@OperateState money,@HandledByNewWms bit,@State int,@OrderOut int)UPDATE [Orderxxx] SET [OperateState] = @OperateState,[HandledByNewWms] = @HandledByNewWms WHERE (([Orderxxx].[State] = @State) And ([Orderxxx].[OrderOut] = @OrderOut) And ([Orderxxx].[PricingExpressProductCode] IN ('UKNIR')))  
  23. inputbuf 
  24. unknown  
  25. frame procname=unknown line=1 sqlhandle=0x000000000000000000000000000000000000000000000000 
  26. UPDATE [Orderxxx] SET [OperateState] = @OperateState,[HandledByNewWms] = @HandledByNewWms WHERE (([Orderxxx].[State] = @State) And ([Orderxxx].[OrderOut] = @OrderOut) And ([Orderxxx].[PricingExpressProductCode] IN ('UKNIR')))  
  27. frame procname=adhoc line=1 stmtstart=134 sqlhandle=0x020000009d376d18a17e7ea51289d8caa2fb4de65c976389 
  28. executionStack 
  29. process id=process5c26988 taskpriority=0 logused=9892 waitresource=KEY: 33:72057597785604096 (70f5b089bb2b) waittime=4813 ownerId=31579268946 transactionname=user_transaction lasttranstarted=2015-09-24T10:27:01.357 XDES=0x98312f950 lockMode=U schedulerid=16 kpid=9184 status=suspended spid=454 sbid=0 ecid=0 priority=0 trancount=2 lastbatchstarted=2015-09-24T10:27:01.490 lastbatchcompleted=2015-09-24T10:27:01.487 clientapp=.Net SqlClient Data Provider hostname=CK1-WIN-WEB02 hostpid=37992 loginname=ck1.biz isolationlevel=read committed (2) xactid=31579268946 currentdb=33 lockTimeout=4294967295 clientoption1=671088672 clientoption2=128056 
  30. process-list 
  31. deadlock victim=process5c26988 
  32. deadlock-list 

咋一看上面的錯誤信息,可以發現兩條相同的語句造成的死鎖,但是這么短的語句不可能持有排他鎖太久

記一次公司倉庫數據庫服務器死鎖過程及解決辦法

再仔細分析一下錯誤日志,發現都死鎖在同一個非聚集索引上,再問了一下開發,開發那邊說,這條語句是在一個大事務里面,這個事務會做7、8件事

記一次公司倉庫數據庫服務器死鎖過程及解決辦法

索引屬性

記一次公司倉庫數據庫服務器死鎖過程及解決辦法

還有索引里面的數據,發現很多重復值

記一次公司倉庫數據庫服務器死鎖過程及解決辦法

SQL語句是這樣的

 

 
  1. (@OperateState money,@HandledByNewWms bit,@State int,@OrderOut int
  2. @HandledByNewWms=(1) @OperateState=($1.0000) @OrderOut=(4055484) @State=(3)  
  3. UPDATE [Orderxxx] SET [OperateState] = $1.0000,[HandledByNewWms] = 1 
  4. WHERE (([Orderxxx].[State] = 3) And ([Orderxxx].[OrderOut] = 4055484) And ([Orderxxx].[PricingExpressProductCode] IN ('UKRRM','UKRLE'))) 

下圖為語句生成的執行計劃

記一次公司倉庫數據庫服務器死鎖過程及解決辦法

當時的情況是大量SQL語句被阻塞,而阻塞的語句正是下面這條語句

記一次公司倉庫數據庫服務器死鎖過程及解決辦法

 

 
  1. UPDATE [Orderxxx] SET [OperateState] = $1.0000,[HandledByNewWms] = 1 
  2. WHERE (([Orderxxx].[State] = 3) And ([Orderxxx].[OrderOut] = 4055484) And ([Orderxxx].[PricingExpressProductCode] IN ('UKRRM','UKRLE'))) 

解決方法

上面得出幾個癥狀

1、update語句是在一個大事務里面,事務太大導致其他session等待排他鎖的時間變長

2、大家都在使用同一個非聚集索引,并掃描PricingExpressProductCode字段

3、索引里的重復值很多

從上面的癥狀基本可以判斷,這個非聚集索引無啥用,可以禁用之

 

 
  1. ALTER INDEX [IX_PricingExpressProductCode_State] ON [dbo].[Orderxxx] DISABLE 

禁用之后,死鎖消失,問題解決,倉庫的怨氣也隨之消失

這一次排查過程時間有點長,但是很好定位,SQL Server錯誤日志給出了足夠的信息定位死鎖問題,所以遇到問題的時候一定要分析清楚日志

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品www久久久久久广东| 国产精品7m视频| 国产日韩欧美视频| 91香蕉亚洲精品| 欧美寡妇偷汉性猛交| 欧美日韩国产一区中文午夜| 欧美老少做受xxxx高潮| 青青久久av北条麻妃黑人| 91精品国产99| 欧美亚洲日本网站| 欧美电影免费观看| 日韩成人黄色av| 欧美视频二区36p| 欧美日韩xxx| 日韩小视频网址| 国产亚洲精品久久久久久牛牛| 91欧美激情另类亚洲| 精品国产91久久久| 国产精品久久久久免费a∨| 国产午夜精品全部视频在线播放| 国产精品爽黄69| 欧美黑人视频一区| 欧美电影电视剧在线观看| 亚洲激情久久久| 亚洲综合中文字幕在线观看| 国产69精品久久久久99| 欧美亚洲国产视频| 欧美激情久久久| 国产成人91久久精品| 91成人性视频| 欧美激情精品久久久久久黑人| 在线播放日韩精品| 国产成人精品电影| 亚洲精品日韩久久久| 97视频在线观看免费高清完整版在线观看| 成人午夜在线视频一区| 亚洲一区二区福利| 91精品国产乱码久久久久久蜜臀| 成人欧美一区二区三区在线湿哒哒| 亚洲а∨天堂久久精品喷水| 欧美高清在线观看| 欧洲成人在线观看| 日韩精品欧美激情| 亚洲美女av网站| 91国产精品91| 国产视频在线观看一区二区| 91在线直播亚洲| 欧美疯狂做受xxxx高潮| 久久亚洲综合国产精品99麻豆精品福利| 97久久久免费福利网址| 久久精品人人做人人爽| 国产精品一区二区三区毛片淫片| 蜜臀久久99精品久久久无需会员| 2019中文在线观看| 国产精品日韩在线播放| 久久精品久久久久电影| 亚洲精品丝袜日韩| 国产成人短视频| 欧美黑人一区二区三区| 亚洲欧美激情精品一区二区| 日本91av在线播放| 精品视频久久久久久久| 日韩成人av在线| 在线观看亚洲区| 国产精品视频导航| 欧美日韩中文字幕综合视频| 岛国av一区二区三区| 国产日韩欧美一二三区| 国产日韩在线看| 国产亚洲欧洲黄色| 免费91在线视频| 中文字幕九色91在线| 国产成人久久久| 亚洲精品成人久久久| 日韩免费黄色av| 日韩不卡中文字幕| 亚洲人av在线影院| 亚洲精品白浆高清久久久久久| 日韩在线播放一区| 欧美丰满少妇xxxx| 日韩中文字幕在线视频播放| 欧美日韩在线第一页| 精品国产乱码久久久久久天美| 伊人久久男人天堂| 最新国产成人av网站网址麻豆| 日韩大片在线观看视频| 久久夜精品va视频免费观看| 欧美一性一乱一交一视频| 久久久欧美精品| 中文字幕精品视频| 国内成人精品视频| xvideos亚洲人网站| 亚洲精品乱码久久久久久金桔影视| 欧美老女人在线视频| 午夜精品福利电影| 亚洲欧美中文字幕在线一区| 久久久成人精品视频| 啪一啪鲁一鲁2019在线视频| 精品无人区太爽高潮在线播放| 亚洲国产精品女人久久久| 亚洲精品在线观看www| 日韩视频在线免费| 亚洲欧美成人一区二区在线电影| 性欧美长视频免费观看不卡| 色悠久久久久综合先锋影音下载| 清纯唯美亚洲激情| 久久精品亚洲国产| 亚洲国产精品久久久久秋霞不卡| 欧美在线一区二区三区四| 亚洲高清不卡av| 成人免费大片黄在线播放| 国产精品欧美一区二区| 日韩一区二区久久久| 亚洲精品wwww| 日本一区二三区好的精华液| 欧美日韩亚洲一区二区三区| 国产精品自拍视频| 免费不卡在线观看av| 国产精品久久久久久久久久免费| 国产精品久久久久一区二区| 精品久久久久久久中文字幕| 奇米四色中文综合久久| 亚洲国产成人av在线| 成人有码在线播放| 日韩电影第一页| 国产精品香蕉国产| 亚洲女成人图区| 伊人青青综合网站| 国产精品一区二区3区| 亚洲欧美在线第一页| 亚洲欧美日韩国产成人| 在线精品国产欧美| 在线看日韩av| 欧美激情第99页| 在线播放日韩专区| 45www国产精品网站| 91在线色戒在线| 日韩色av导航| 久久免费视频网站| 精品久久久久久中文字幕一区奶水| 国模私拍视频一区| 91久久中文字幕| 97视频色精品| 欧美成人精品一区| 国外成人在线视频| 中文字幕亚洲一区二区三区五十路| 国产精品一区av| 欧美裸体xxxx| 97精品一区二区三区| 亚洲精品福利免费在线观看| 欧美亚洲国产视频| 日本精品视频在线播放| 国产精品成人一区二区三区吃奶| 国产精品国产三级国产专播精品人| 欧美日韩高清区| 日韩毛片在线观看| 欧美日韩免费观看中文| 国产精品激情av在线播放| 777国产偷窥盗摄精品视频| 国产亚洲成精品久久| 欧美乱人伦中文字幕在线| 亚洲激情在线视频| 亚洲国产天堂久久综合| 日韩欧美在线免费|