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