Springboot @Transactional大事務(wù)處理的幾點(diǎn)建議
1.大事務(wù):
總體任務(wù)對(duì)應(yīng)的事務(wù)運(yùn)行時(shí)間比較長,長時(shí)間未提交的事務(wù)。
2.大事務(wù)的危害:
a.并發(fā)情況下,數(shù)據(jù)庫連接池資源占滿。大事務(wù)提交不及時(shí),導(dǎo)致連接資源釋放緩慢。
b.數(shù)據(jù)庫死鎖和鎖等待。mysql innodb存儲(chǔ)引擎背景下,事務(wù)如果占用了排他鎖,會(huì)容易導(dǎo)致并發(fā)情況下數(shù)據(jù)死鎖或者鎖等待。
c.大事務(wù)Rt時(shí)間長,容易導(dǎo)致接口超時(shí)。
d.大事務(wù)回滾時(shí)間長。
e.數(shù)據(jù)庫主從架構(gòu)下,數(shù)據(jù)同步延遲
3.解決辦法
3.1 將聲明式事務(wù)的@Transactional方式 合理的替換為 編程式事務(wù)TransactionTemplate 的方式
聲明式事務(wù)的粒度最小是整個(gè)方法,可能會(huì)導(dǎo)致業(yè)務(wù)里不必要的邏輯都加了事務(wù)。編程式事務(wù)細(xì)化需要加事務(wù)的邏輯上,形成實(shí)際有用的事務(wù)塊。
@Autowired
private TransactionTemplate transactionTemplate;
public void testTransaction() {
transactionTemplate.execute(new TransactionCallbackWithoutResult() {
@Override
protected void doInTransactionWithoutResult(TransactionStatus transactionStatus) {
try {
// .... 業(yè)務(wù)代碼
} catch (Exception e){
//回滾
transactionStatus.setRollbackOnly();
}
}
});
}
3.2 將查詢放在事務(wù)方法外
使用@Transactional 又想避免產(chǎn)生大事務(wù),需對(duì)方法進(jìn)行拆分,將不需要事務(wù)管理的邏輯與事務(wù)操作分開
@Service
public class TransactionTestService{
// 避免同一個(gè)類內(nèi)部方法相互調(diào)用,實(shí)例方法調(diào)用代理方法而導(dǎo)致事務(wù)失效
@Resource
private TransactionTestService service;
public void create(ParamDto dto){
queryData1();
queryData2();
service.save(dto);
}
//事務(wù)操作
@Transactional(rollbackFor = Exception.class)
public void save(ParamDto dto){
paramDao.insert(dto);
}
}
3.3 避免跨服務(wù)間的遠(yuǎn)程調(diào)用
服務(wù)間的通訊及服務(wù)之間的調(diào)用時(shí)間 受網(wǎng)絡(luò)環(huán)境和遠(yuǎn)端接口Rt時(shí)間的影響,可能會(huì)比較耗時(shí)。
反例:
//事務(wù)操作
@Transactional(rollbackFor = Exception.class)
public void save(ParamDto dto){
// 調(diào)用了其他服務(wù)
otherRemoteApi();
paramDao.insert(dto);
}
修改為:
@Autowired
private TransactionTemplate transactionTemplate;
public void save(ParamDto dto){
// 調(diào)用了其他服務(wù)
otherRemoteApi();
transactionTemplate.execute(new TransactionCallbackWithoutResult() {
@Override
protected void doInTransactionWithoutResult(TransactionStatus transactionStatus) {
try {
paramDao.insert(dto);
} catch (Exception e){
//回滾
transactionStatus.setRollbackOnly();
}
}
});
}
3.4 事務(wù)中不應(yīng)該一次性處理太多的數(shù)據(jù),可以使用分批執(zhí)行
3.5事務(wù)中的方法可以根據(jù)業(yè)務(wù)使用異步執(zhí)行
到此這篇關(guān)于Springboot @Transactional大事務(wù)處理的幾點(diǎn)建議的文章就介紹到這了,更多相關(guān)Springboot @Transactional大事務(wù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
如何在Spring?Boot框架中使用攔截器實(shí)現(xiàn)URL限制
在Spring?Boot框架中,您可以使用攔截器(Interceptor)來控制限制URL列表,本文通過一個(gè)簡單的示例給大家介紹Spring?Boot?攔截器實(shí)現(xiàn)URL限制的操作方法,感興趣的朋友跟隨小編一起看看吧2023-08-08
序列化版本號(hào)serialVersionUID的作用_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
Java序列化是將一個(gè)對(duì)象編碼成一個(gè)字節(jié)流,反序列化將字節(jié)流編碼轉(zhuǎn)換成一個(gè)對(duì)象,這篇文章主要介紹了序列化版本號(hào)serialVersionUID的作用,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05
基于Java實(shí)現(xiàn)收發(fā)電子郵件功能
Email就是電子郵件,我們平常使用的QQ郵箱,網(wǎng)易郵箱,F(xiàn)oxmail都是用來收發(fā)郵件的,利用Java程序也可以完成收發(fā)電子郵件的功能,本文就來為大家詳細(xì)講講實(shí)現(xiàn)步驟2022-07-07

