hibernate同时插入两条相同数据(偶尔)原因调查
項目測試階段,遇到一個問題:
一條數據,會被同時更新兩條,而且還是偶發的,這個就比較尷尬了,代碼也順過了,單人測試也測試過了,沒什么問題。后來,在晚上找資料時,找到一篇博客,博文如下:
前幾天和朋友討論他遇到的問題:為什么hibernate會插入兩條相同的記錄(偶爾)?
是這么回事:
有兩個表: A表 ,B表 一對一的關系,通過Quartz定時任務輪循A表,如果A表有新記錄,則插入一條新記錄到B表,如果B表已存在記錄則更新此記錄;
為什么新插入到B表的數據偶爾會出現兩條呢?
還有個奇怪的事,在本地測試永遠不會出現兩條相同的,放在測試服務器就偶爾會出現。
當時看了仔細看過代碼肯定不會有問題,剛開始以為是hibernate持久化引起的,后來在save()方法后調用flush()問題
還是沒有解決?
由于剛進公司對公司整個架構也不是太了解,后來去請教架構師,找到問題可能出現集群上,因為測試服務器是集群環境,而本地不是,而在集群環境相當于啟動了多個定時任務在做相同的事情,因而出現了這種問題,后來將定時任務提取出來,問題不再出現,問題終于解決。
其實公司原來的定時任務都是放到一個工程,是單獨放出來(不在集群環境內)。
之后,和同事兩個人同時登陸一個賬號,同時提交數據,終于發現了問題所在!MD,一個事務中處理的邏輯太多了,導致兩個插入任務最后一期提交了,OK,問題找到了,接下來就是解決方案了:
1.加入樂觀鎖;
2.在賬號登錄的時候,做限制,同一個用戶只允許在一個客戶端登錄。
不過,這兩個方法,我還沒有實踐,等實際操作完,我再來更新文章!
方法一驗證:
1.加入樂觀鎖的方法,這里推薦一篇博客:
https://www.cnblogs.com/otomedaybreak/archive/2012/01/27/2330008.html
博客講的很詳細,這里就不再贅述。有一點需要注意,作為樂觀鎖的標識字段,程序不能對他們做操作,由hibernate來完成!
關于方法二,就懶得驗證了。。。。
僅做記錄參考,如有問題,請各位大佬指正!!!
總結
以上是生活随笔為你收集整理的hibernate同时插入两条相同数据(偶尔)原因调查的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Spring Boot 集成 Activ
- 下一篇: 缓存一致性(MESI)