<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
在測試階段,巨量資料並行的情況下,發現sql語句造成表的死鎖,過一段時間,死鎖消失。於是進行排查
報錯如下:
對應的sql語句如下:
@Insert("replace into ${tableName}( windcode,date, n" + " code, high, open, low, n" + " `close`, volume, turnover,gtm_modify) " + "values (#{obj.windcode},#{obj.date},#{obj.code},#{obj.high},#{obj.open},#{obj.low},#{obj.close},#{obj.volume},#{obj.turnover},#{obj.updateTime})" ) int insertOne(@Param("obj") KDTO obj, @Param("tableName") String tableName);
在排除了資料問題和執行緒重複呼叫以後,我們關注了一下sql語句本身。 看了網上很多經驗分享,覺得問題可能出現在 Replace Into 語句上。
首先我們分析一下為什麼並行replace into導致MySQL死鎖
Replace into 一般作用是,當存在衝突時,會把舊記錄替換成新的記錄。也就是說這條語句執行,分為了兩個大步:判斷和執行
1.判斷:
首先判斷我們需要操作的記錄是否存在(根據主鍵或者唯一索引判斷)
2.操作:
測試:
建立表
插入資料:
我們使用replace into語句去執行一個已經存在的資料:
可以清楚的發現,影響的行數是兩行
第一行的資料被修改了
我們使用replace into語句去執行一個不存在的資料:
可以清楚的發現,影響的行數是一行
執行了插入操作:
邏輯非常的清晰,但是這種單條sql語句在什麼情況下會出現死鎖呢?我們就要去考慮這個加鎖的時機。
正常的插入邏輯是:
發現錯誤:
轉換模式:
如果發生uk衝突的索引是最後一個唯一索引、沒有外來鍵參照、且不存在delete trigger時,使用UPDATE ROW的方式來解決衝突;
否則,使用DELETE ROW + INSERT ROW的方式解決衝突。
更新記錄:
所以死鎖的問題多半就會出現在X記錄鎖上面。
死鎖分析:
所以再多執行緒高並行的環境狀態下,存在兩個事務同時去獲取一個記錄的修改的情況:
事務1 | 事務2 |
---|---|
LOCK_X LOCK_NOT_GAP | - |
- | LOCK_X-LOCK_NEXT_KEY 阻塞 |
LOCK_S-LOCK_NEXT_KEY | 死鎖回滾 |
所以在等待執行期間sql會有死鎖報錯,高並行環境下的死鎖也就出現了,再事務執行完成回滾操作以後,死鎖回滾,也就解釋了死鎖消失的問題。
經過多方討論,最終決定使用 insetr + ON DUPLICATE KEY UPDATE語句替換高並行環境下的Replace Into語句解決死鎖問題。
ON DUPLICATE KEY UPDATE語句的作用是:
若該資料的主鍵值/ UNIQUE KEY 已經在表中存在,則執行更新操作, 即UPDATE 後面的操作。
否則插入一條新的記錄。
實現了Replace Into有相同的查重替換功能,而避免了高並行的死鎖問題。
但是UPDATE操作效能相比DELETE操作會有一定的效能上的影響,需要後續測試跟進。
到此這篇關於高並行狀態下Replace Into造成的死鎖問題解決的文章就介紹到這了,更多相關Replace Into死鎖內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45