婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

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

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

熱門標簽:地圖標注跑線下市場 濮陽清豐400開頭的電話申請 真3地圖標注 地圖標注可以編輯地名嗎 臺灣外呼系統軟件 樂昌電話機器人 疫情時期電話機器人 南京怎么申請400這種電話 南通智能外呼系統怎么樣

死鎖的四個必要條件:

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

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

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

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

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

EXEC xp_readerrorlog 0,1,NULL,NULL,'2015-09-21','2015-10-10','DESC'
   waiter id=process5c30e08 mode=U requestType=wait
  waiter-list
   owner id=process5c26988 mode=X
  owner-list
  keylock hobtid=72057597785604096 dbid=33 objectname=stoxxx.dbo.Orderxxx indexname=IX_PricingExpressProductCode_State id=lock17fa96980 mode=X associatedObjectId=72057597785604096
   waiter id=process5c26988 mode=U requestType=wait
  waiter-list
   owner id=process5c30e08 mode=X
  owner-list
  keylock hobtid=72057597785604096 dbid=33 objectname=stoxxx.dbo.Orderxxx indexname=IX_PricingExpressProductCode_State id=lock87d69e780 mode=X associatedObjectId=72057597785604096
 resource-list
(@OperateState money,@HandledByNewWms bit,@State int,@OrderOut int)
UPDATE [Orderxx] SET [OperateState] = @OperateState,[HandledByNewWms] = @HandledByNewWms WHERE (([Orderxxx].[State] = @State) And ([Orderxxx].[OrderOut] = @OrderOut) And ([Orderxxx].[PricingExpressProductCode] IN ('UKNIR')))  
  inputbuf
unknown   
   frame procname=unknown line=1 sqlhandle=0x000000000000000000000000000000000000000000000000
UPDATE [Orderxxx] SET [OperateState] = @OperateState,[HandledByNewWms] = @HandledByNewWms WHERE (([Orderxxx].[State] = @State) And ([Orderxxx].[OrderOut] = @OrderOut) And ([Orderxxx].[PricingExpressProductCode] IN ('UKNIR')))   
   frame procname=adhoc line=1 stmtstart=134 sqlhandle=0x020000009d376d18a17e7ea51289d8caa2fb4de65c976389
  executionStack
  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
(@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')))  
  inputbuf
unknown   
   frame procname=unknown line=1 sqlhandle=0x000000000000000000000000000000000000000000000000
UPDATE [Orderxxx] SET [OperateState] = @OperateState,[HandledByNewWms] = @HandledByNewWms WHERE (([Orderxxx].[State] = @State) And ([Orderxxx].[OrderOut] = @OrderOut) And ([Orderxxx].[PricingExpressProductCode] IN ('UKNIR')))   
   frame procname=adhoc line=1 stmtstart=134 sqlhandle=0x020000009d376d18a17e7ea51289d8caa2fb4de65c976389
  executionStack
  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
 process-list
 deadlock victim=process5c26988
deadlock-list

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

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

索引屬性

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


SQL語句是這樣的

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

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

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

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

解決方法

上面得出幾個癥狀

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

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

3、索引里的重復值很多

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

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


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

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

您可能感興趣的文章:
  • mysql 數據庫死鎖原因及解決辦法
  • Mysql 數據庫死鎖過程分析(select for update)
  • 簡單說明Oracle數據庫中對死鎖的查詢及解決方法
  • InnoDB數據庫死鎖問題處理
  • Mybatis update數據庫死鎖之獲取數據庫連接池等待
  • MySQL數據庫的一次死鎖實例分析
  • 講解Oracle數據庫中結束死鎖進程的一般方法
  • 查詢Sqlserver數據庫死鎖的一個存儲過程分享
  • MySQL數據庫之Purge死鎖問題解析
  • 5分鐘快速了解數據庫死鎖產生的場景和解決方法

標簽:馬鞍山 福建 南京 阿里 廣安 陜西 通遼 河北

巨人網絡通訊聲明:本文標題《記一次公司倉庫數據庫服務器死鎖過程及解決辦法》,本文關鍵詞  記,一次,公司,倉庫,數據庫,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《記一次公司倉庫數據庫服務器死鎖過程及解決辦法》相關的同類信息!
  • 本頁收集關于記一次公司倉庫數據庫服務器死鎖過程及解決辦法的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产欧美日韩不卡免费| 精品视频在线免费| 精品一区二区三区在线观看国产| 亚洲高清视频中文字幕| 亚洲一二三级电影| 全部av―极品视觉盛宴亚洲| 轻轻草成人在线| 久久精品国产在热久久| 国模娜娜一区二区三区| 久久国产精品99精品国产| 精品一区二区三区在线观看国产| 久久精品国产77777蜜臀| 麻豆精品精品国产自在97香蕉| 日韩极品在线观看| 国内精品国产三级国产a久久| 国产中文字幕一区| 不卡av在线网| 色94色欧美sute亚洲线路一久 | 日韩欧美亚洲国产另类| 欧美丰满高潮xxxx喷水动漫| 欧美一区二区黄色| 久久精品欧美日韩| 亚洲日本丝袜连裤袜办公室| 亚洲成av人片在线| 久久91精品国产91久久小草| 成人性生交大片免费看中文| 在线视频综合导航| 欧美成人vr18sexvr| 国产精品国产成人国产三级| 亚洲国产日韩综合久久精品| 免费久久精品视频| eeuss鲁片一区二区三区| 欧美日韩亚洲综合一区| 久久精品人人爽人人爽| 一区二区久久久久| 国产成人av网站| 欧美日韩一区不卡| 亚洲国产成人午夜在线一区| 五月天国产精品| 成人aaaa免费全部观看| 欧美一级黄色片| 亚洲精品乱码久久久久久日本蜜臀| 日韩av中文在线观看| 91在线视频观看| 精品美女一区二区三区| 亚洲欧美国产77777| 久久99精品国产.久久久久| 在线影院国内精品| 亚洲欧洲成人精品av97| 蜜桃久久精品一区二区| 91国产成人在线| 中文字幕va一区二区三区| 免费成人性网站| 欧美久久婷婷综合色| 国产精品国产三级国产专播品爱网| 久久99精品国产.久久久久久| 色成人在线视频| 中文字幕av一区二区三区高| 久久精品噜噜噜成人av农村| 欧美日韩亚洲高清一区二区| 一区二区三区四区乱视频| 高清视频一区二区| 日韩欧美国产高清| 日韩经典一区二区| 欧美日韩视频在线观看一区二区三区 | 精品国产三级a在线观看| 亚洲激情图片小说视频| 91啦中文在线观看| 最好看的中文字幕久久| 成人av电影在线观看| 国产日韩精品一区二区浪潮av| 国模冰冰炮一区二区| 久久综合九色欧美综合狠狠 | 91精品国产黑色紧身裤美女| 亚洲国产中文字幕在线视频综合| 色综合天天视频在线观看| 国产精品超碰97尤物18| 色综合一个色综合亚洲| 亚洲一区二区中文在线| 欧美日韩一区二区三区不卡| 日本午夜精品一区二区三区电影| 在线观看日韩电影| 亚洲成人av在线电影| 欧美视频一区二区三区在线观看| 亚洲国产精品麻豆| 91精品综合久久久久久| 黑人精品欧美一区二区蜜桃 | 国产精品资源网| 国产精品色婷婷| 在线亚洲一区二区| 性做久久久久久| 日韩欧美激情一区| 国产精品亚洲一区二区三区妖精 | 日本韩国欧美一区二区三区| 亚洲第一激情av| 久久亚区不卡日本| 99久久精品免费观看| 一区二区免费在线播放| 精品国产一区久久| 99在线精品观看| 日韩国产欧美在线视频| 国产色婷婷亚洲99精品小说| 91捆绑美女网站| 蜜桃久久av一区| 国产精品白丝在线| 日韩美女一区二区三区四区| 成人av在线电影| 日韩在线播放一区二区| 国产精品毛片久久久久久久 | 极品瑜伽女神91| 一区二区三区免费| 26uuu精品一区二区| 色婷婷av一区二区三区大白胸| 日韩av中文字幕一区二区| 成人免费在线观看入口| 欧美一级高清片在线观看| 一本久久精品一区二区| 国产一区二区三区四区五区美女| 亚洲在线视频一区| 国产精品嫩草99a| 精品国产成人系列| 精品视频在线免费| 成人av在线电影| 国产美女娇喘av呻吟久久| 亚洲成人黄色小说| 亚洲精品视频免费看| 久久男人中文字幕资源站| 在线不卡中文字幕| 色婷婷亚洲精品| 成人激情av网| 国产美女精品人人做人人爽| 免费成人美女在线观看| 天天影视涩香欲综合网| 伊人性伊人情综合网| 亚洲欧美在线视频观看| 亚洲精品在线免费播放| 欧美一区二区网站| 欧美视频一区在线| 在线观看日韩av先锋影音电影院| www.亚洲色图.com| 高清久久久久久| 高清不卡一二三区| 国产激情一区二区三区| 国产在线精品一区二区三区不卡 | 久久久久久久综合| 精品国产欧美一区二区| 日韩视频在线一区二区| 日韩欧美黄色影院| 久久综合九色综合97_久久久| 精品人伦一区二区色婷婷| 久久综合久久综合久久| 久久综合给合久久狠狠狠97色69| 日韩精品资源二区在线| 精品国产一区二区亚洲人成毛片| 日韩一二三区不卡| 精品999久久久| 中文字幕乱码久久午夜不卡| 国产精品久久久久久亚洲毛片| 国产精品丝袜91| 亚洲人成网站色在线观看| 夜夜爽夜夜爽精品视频| 亚洲国产精品久久久男人的天堂 | 国产成人综合亚洲91猫咪| 国产高清精品网站| 91原创在线视频| 欧美日韩精品一区二区三区蜜桃| 欧美精品第一页| 欧美日本国产视频| 精品国产亚洲在线| 亚洲视频在线观看一区| 亚洲成人激情自拍| 国产主播一区二区三区| 成人免费福利片| 色天使色偷偷av一区二区| 制服.丝袜.亚洲.中文.综合| 欧美tickle裸体挠脚心vk| 中文字幕精品—区二区四季| 一区二区三区精品视频| 久久97超碰国产精品超碰| 国产另类ts人妖一区二区| 色猫猫国产区一区二在线视频| 欧美日韩久久久一区| 欧美精品一区二区三区视频| 中文字幕不卡一区| 视频在线观看一区二区三区| 国产高清精品久久久久| 欧美日韩精品专区| 国产人成亚洲第一网站在线播放 | 3751色影院一区二区三区| 久久精品欧美一区二区三区麻豆| 一区二区三区精密机械公司| 韩国成人精品a∨在线观看| 91日韩在线专区| 久久久噜噜噜久久中文字幕色伊伊| 日韩美女精品在线| 国产米奇在线777精品观看| 色猫猫国产区一区二在线视频| 日韩精品专区在线影院重磅| 午夜久久福利影院| 不卡视频免费播放|