精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Spring事務長了個腿?輕松掌握技巧告別長事務煩惱!

開發 前端
本文討論了長事務的危害及解決方案。首先,我們探討了長事務導致的問題,包括數據庫連接池耗盡、死鎖等。其次,介紹了兩種解決策略:采用編程式事務和對方法進行拆分。

大家好,我是飄渺。今天繼續DDD&微服務專欄。

在之前的文章 基于DDD的訂單創建 流程中,我們留下了一個問題:在createOrder()方法中,我將調用遠程接口獲取購物車詳情、遠程庫存校驗、訂單保存放在一個事務中,顯然這并不是一個正確的做法,因為它會導致長事務,今天就讓我們來解決這個問題。

圖片圖片

為什么會產生長事務

首先,讓我們來分析一下產生長事務的原因。

在Spring中,@Transactional注解是基于AOP實現的,本質上是在目標方法執行前后進行攔截。在目標方法執行前加入或創建一個事務,在方法執行后,根據實際情況選擇提交或回滾事務。

當Spring遇到該注解時,會自動從數據庫連接池中獲取連接并開啟事務,然后綁定到ThreadLocal上,對于@Transactional注解包裹的整個方法都是使用同一個連接。如果出現耗時的操作,如第三方接口調用、業務邏輯復雜、大批量數據處理等,就會導致占用連接的時間很長,數據庫連接一直被占用不釋放。一旦類似操作過多,就會導致數據庫連接池耗盡。

在開頭的實例中,一個事務中執行RPC操作是典型的長事務問題。類似的操作還包括在事務中進行大量數據查詢、業務規則處理等。

長事務會產生哪些問題

長事務引發的常見危害有:

  1. 數據庫連接池被占滿,應用無法獲取連接資源;
  2. 容易引發數據庫死鎖;
  3. 數據庫回滾時間長;
  4. 在主從架構中會導致主從延時變大。

如何避免長事務

既然知道了長事務的危害,那么在開發中如何避免這個問題呢?

很明顯,解決長事務的宗旨就是 對事務方法進行拆分,盡量讓事務變小,變快,減小事務的顆粒度。

編程式事務

因此,我們可以采用編程式事務替代聲明式事務@Transactional。在Spring項目中,可以注入TransactionTemplate對象,然后手動控制事務范圍。改造過后的代碼如下所示:

public String createOrder(OrderCreateRequest orderCreateRequest) {
 // 獲取購物車詳情
 ShoppingCartDetailDTO shoppingCartDetailDTO = cartRemoteFacade.queryCheckedCartItemByUserId(orderCreateRequest.getCustomerId());
 List<CartItemDTO> cartItemList = shoppingCartDetailDTO.getCartItemDtoS();

 //校驗庫存
 checkInventory(cartItemList);
 ...
 
 transactionTemplate.executeWithoutResult(status -> {  
     orderRepository.save(tradeOrder);
  eventPublisher.publishEvent(new OrderCreatedEvent(tradeOrder)); 
 });

 return orderSn;
}

然而,這里涉及到另一個問題:在保存訂單后我們通過EventPublisher發布了一個事件,讓監聽者來處理剩下的業務邏輯,(在Dailymart中創建訂單后需要進行庫存預扣),在默認情況下,Spring的事件監聽機制是同步的將代碼進行解耦,我們希望庫存扣減如果出現失敗需要回滾訂單,而編程式事務無法控制監聽者的事務。因此,在這種場景下并不適合使用編程式事務來處理。

敲黑板:使用編程式事務替代聲明式事務是解決長事務最簡單的實現方式,在大部分場景下都可以采用。在使用時要注意編程式事務搭配EventPublisher時無法控制監聽者的事務。

對方法進行拆分

另外一種常見的處理措施就是將方法進行拆分,將大方法拆成小方法,將不需要事務管理的邏輯與事務操作拆開。

public String createOrder(OrderCreateRequest orderCreateRequest) {
 // 獲取購物車詳情
 ShoppingCartDetailDTO shoppingCartDetailDTO = cartRemoteFacade.queryCheckedCartItemByUserId(orderCreateRequest.getCustomerId());
 List<CartItemDTO> cartItemList = shoppingCartDetailDTO.getCartItemDtoS();

 //校驗庫存
 checkInventory(cartItemList);
 ...
 
 this.saveOrder(tradeOrder)

 return orderSn;
}

@Transactional(rollbackFor = RuntimeException.class)
private void saveOrder(TradeOrder tradeOrder){
 orderRepository.save(tradeOrder);
 eventPublisher.publishEvent(new OrderCreatedEvent(tradeOrder)); 
}

在上述代碼中,獲取購物車詳情與庫存校驗不需要事務,將其與事務方法saveOrder()分開。然而,這樣的簡單拆分會導致事務不生效。這又涉及到另一個知識點:

@Transactional注解的聲明式事務是通過spring aop起作用的,而spring aop需要生成代理對象,直接在同一個類中方法調用使用的還是原始對象,事務不生效。其他幾個常見的事務不生效的場景為:

  • @Transactional 應用在非 public 修飾的方法上
  • @Transactional 注解屬性 propagation 設置錯誤
  • @Transactional 注解屬性 rollbackFor 設置錯誤
  • 同一個類中方法調用,導致@Transactional失效
  • 異常被catch捕獲導致@Transactional失效

正確的拆分方法應該使用下面兩種:

  1. 將方法放入另一個類,如新增一個Manager層,通過Spring注入,這樣符合了在對象之間調用的條件。詳細說明可以參考我的文章為什么阿里建議給MVC三層架構再加一層Manager層!。
  2. 啟動類添加@EnableAspectJAutoProxy(exposeProxy = true),方法內使用AopContext.currentProxy()獲得代理類,使用事務。
SpringBootApplication.java  
  
@EnableAspectJAutoProxy(exposeProxy = true)  
@SpringBootApplication  
public class SpringBootApplication {}



public String createOrder(OrderCreateRequest orderCreateRequest) {
 ...
 OrderService orderService = (OrderService)AopContext.currentProxy(); 
    orderService.saveData(tradeOrder);  
 return orderSn;
}

@Transactional(rollbackFor = RuntimeException.class)
private void saveOrder(TradeOrder tradeOrder){
 orderRepository.save(tradeOrder);
 eventPublisher.publishEvent(new OrderCreatedEvent(tradeOrder)); 
}

然而,Dailymart項目是基于DDD的分層架構模型實現。原來的業務邏輯是在應用服務編寫,在我們項目中只需要將保存訂單的邏輯放在領域服務層,由領域服務保證事務,而應用服務層負責組裝業務邏輯。最終代碼如下:

private final TradeOrderService tradeOrderService;

@Override  
// @Transactional(rollbackFor = RuntimeException.class)  
public String createOrder(OrderCreateRequest orderCreateRequest) {  
    // 生成訂單編號  
    String orderSn = IdUtils.nextIdStr();  
    // 獲取購物車詳情  
    ShoppingCartDetailDTO shoppingCartDetailDTO = cartRemoteFacade.queryCheckedCartItemByUserId(orderCreateRequest.getCustomerId());  
    List<CartItemDTO> cartItemList = shoppingCartDetailDTO.getCartItemDtoS();  
      
    // 校驗庫存  
    checkInventory(cartItemList);  
 ...
      
    tradeOrderService.save(tradeOrder); 
    return orderSn;  
}

@Service  
@RequiredArgsConstructor(onConstructor = @__(@Autowired))  
public class TradeOrderServiceImpl implements TradeOrderService {  
      
    private final ApplicationEventPublisher eventPublisher;  
      
    private final OrderRepository orderRepository;  
      
    @Override  
    @Transactional    
    public void save(TradeOrder tradeOrder) {  
        orderRepository.save(tradeOrder);  
        eventPublisher.publishEvent(new OrderCreatedEvent(tradeOrder));  
    }
}

小結

本文討論了長事務的危害及解決方案。首先,我們探討了長事務導致的問題,包括數據庫連接池耗盡、死鎖等。其次,介紹了兩種解決策略:采用編程式事務和對方法進行拆分。編程式事務提供了手動控制事務范圍的方式,但需要注意搭配EventPublisher可能導致監聽者事務無法控制的問題。對方法進行拆分是一種更通用的方法,能夠減小事務范圍,提高執行效率。最后,通過實際的DDD分層架構示例,展示了在應用服務層和領域服務層中如何組織業務邏輯,確保事務正確性和性能。

責任編輯:武曉燕 來源: JAVA日知錄
相關推薦

2023-05-12 08:02:43

分布式事務應用

2009-11-11 09:31:44

ADO.NET事務處理

2025-07-16 07:05:00

2020-12-30 15:06:39

開發技能代碼

2024-04-10 08:59:39

SpringAOP業務

2009-06-22 09:01:57

Spring聲明式事務

2009-12-10 11:02:44

PHP函數eval()

2024-12-02 08:37:04

2020-08-19 09:45:29

Spring數據庫代碼

2024-12-17 16:44:22

Spring開發

2023-10-30 07:36:19

Spring事務傳播機制

2020-07-17 08:07:54

Spring數據庫事務

2009-06-29 17:54:47

Spring事務隔離

2021-10-29 07:49:22

Spring事務管理

2022-02-14 16:53:57

Spring項目數據庫

2024-05-10 11:52:00

編程C++

2018-02-28 13:49:49

屏幕截取win 10瀏覽器

2009-12-17 14:36:57

Ruby on Rai

2010-01-14 13:59:01

2009-12-11 17:25:00

Grub突破root
點贊
收藏

51CTO技術棧公眾號

日韩欧美一级| 欧美亚洲系列| 国产毛片精品国产一区二区三区| 久久国产精品亚洲| 国产精品久久久久久在线观看| 成人免费网站观看| 中文字幕欧美区| www.久久爱.cn| 99re这里只有精品在线| 91精品天堂福利在线观看| 亚洲国产另类久久精品| 成年人三级黄色片| 涩涩涩在线视频| 综合激情成人伊人| 蜜桃麻豆91| 国产同性人妖ts口直男| 一区二区高清| 欧美成人精品在线| 中文字幕av久久爽一区| 狂野欧美xxxx韩国少妇| 日本久久一区二区三区| 免费一级淫片aaa片毛片a级| 国产黄色免费在线观看| 成人涩涩免费视频| 91久久中文字幕| 99re这里只有精品在线| 亚洲精选一区| 欧美日韩电影在线观看| 免费视频91蜜桃| 偷拍亚洲色图| 精品电影一区二区| 在线成人免费av| 欧美成人家庭影院| 在线观看91精品国产入口| 欧美一级欧美一级| a级影片在线| 中文字幕一区二区三中文字幕| 久久精品国产精品国产精品污| www.蜜桃av.com| 国产综合色在线视频区| 国产精品免费一区豆花| 一级做a爰片久久毛片| 99亚洲伊人久久精品影院红桃| 免费中文字幕日韩| 九色porny丨入口在线| 亚洲视频你懂的| 一区在线电影| 秋霞影院午夜丰满少妇在线视频| 国产区在线观看成人精品| 精品欧美一区二区久久久伦| 亚洲国产成人在线观看| 国产精品888| 91久久精品久久国产性色也91| 日韩欧美一级大片| 视频一区视频二区中文| 国产精品国产福利国产秒拍| 欧美一区二区三区不卡视频| 乱码第一页成人| 国产精品久久久久av| 波多野结衣在线观看视频| 久久婷婷丁香| 国产精品日日做人人爱 | 亚洲网友自拍偷拍| 亚洲国产精品无码观看久久| 3344国产永久在线观看视频| 午夜久久久久久| 亚洲中文字幕无码中文字| 精品丝袜在线| 日本精品一区二区三区四区的功能| 日本男人操女人| 色综合视频一区二区三区日韩| 欧美精品成人一区二区三区四区| 亚洲一区二区三区四区精品| 凹凸成人在线| 亚洲美女自拍视频| 国产视频精品免费| 欧美精品99| 欧美一区二区色| 中文无码av一区二区三区| 久久精品国产亚洲一区二区三区| 51成人做爰www免费看网站| 国产77777| 久久久久久夜精品精品免费| 中文网丁香综合网| 91在线超碰| 欧美亚洲一区二区三区四区| 日韩欧美中文视频| 欧美重口另类| 久久久极品av| 久久国产视频一区| 久久aⅴ国产欧美74aaa| 国产成人成网站在线播放青青| 婷婷国产在线| 亚洲欧美激情在线| 免费高清在线观看免费| 国产精品视频一区视频二区| 亚洲国产精品人久久电影| 亚洲午夜精品久久久久久高潮| 91成人影院| 欧美在线亚洲在线| 国产女18毛片多18精品| 2021国产精品久久精品| 日本xxxxx18| 国产经典一区| 亚洲高清福利视频| 91香蕉视频在线播放| 久久九九99| 99伊人久久| 午夜伦理在线| 色94色欧美sute亚洲线路二| 亚洲成a人无码| 91久久夜色精品国产按摩| 欧美一级在线播放| 黄色小视频免费观看| 国产精品久久久久久久久快鸭 | 秋霞午夜鲁丝一区二区老狼| 国产一区二区三区免费不卡| 欧美jizz18hd性欧美| 欧美性高潮床叫视频 | 久久无码av三级| 2021国产视频| 96sao精品免费视频观看| 亚洲欧美日韩一区在线| 日韩免费观看一区二区| 国产麻豆一精品一av一免费 | 亚洲综合不卡| 国产激情美女久久久久久吹潮| 99se视频在线观看| 色屁屁一区二区| 国产麻豆xxxvideo实拍| 欧美va天堂| 成人乱人伦精品视频在线观看| 国产在线自天天| 欧美视频在线看| 青青草视频网站| 国内视频精品| 国产99视频精品免费视频36| 怡红院在线播放| 91精品国产乱| 欧美风情第一页| 国产在线国偷精品产拍免费yy | 成年人在线观看网站| 日韩欧美亚洲国产一区| 懂色av粉嫩av蜜乳av| 中文久久精品| 久久综合狠狠综合久久综青草| 538在线视频| 日韩电影第一页| 亚洲精品国产精品乱码| a在线播放不卡| 欧美视频在线播放一区| 在线视频亚洲专区| 国产精品成人一区| av色图一区| 91精品国模一区二区三区| 一级性生活免费视频| 国产麻豆精品视频| 久久久久久久香蕉| 大型av综合网站| 97成人精品区在线播放| 久久精品a一级国产免视看成人| 日韩欧美一区二区三区| 国产7777777| 九九久久精品视频| 久久久国内精品| 日本一道高清一区二区三区| 日产日韩在线亚洲欧美| 国产黄色片在线播放| 4438x成人网最大色成网站| 强乱中文字幕av一区乱码| www.欧美.com| 黄色一级免费大片| 一级欧洲+日本+国产| 国产精品一区二| 北岛玲heyzo一区二区| 中文字幕精品—区二区| 国产成人av免费看| 欧美视频在线看| 老熟妇高潮一区二区三区| 波多野结衣中文字幕一区二区三区| 久久久久久久久久久久久国产精品| 欧美色女视频| 99久久无色码| 日韩高清在线| 欧美乱大交xxxxx| 你懂的视频在线| 91精品久久久久久久99蜜桃| 久久午夜免费视频| 亚洲欧洲成人精品av97| 人妻无码中文久久久久专区| 麻豆一区二区三区| 日本中文字幕网址| 欧美激情偷拍自拍| 麻豆久久久9性大片| 97色婷婷成人综合在线观看| 海角国产乱辈乱精品视频| a天堂中文在线88| 精品盗摄一区二区三区| 91女人18毛片水多国产| 精品国产乱码久久久久久天美| 国产精品视频看看| 久久午夜免费电影| 无码人妻精品一区二区三| 男女男精品视频网| 久久成人免费观看| 欧美暴力喷水在线| 日韩欧美在线观看强乱免费| 群体交乱之放荡娇妻一区二区| 国产一区视频在线| 桃花岛tv亚洲品质| 欧美激情免费观看| 麻豆免费在线视频| 国产亚洲成av人片在线观看桃| 超碰福利在线观看| 7777精品伊人久久久大香线蕉完整版| 国产成人一级片| 亚洲综合一区二区精品导航| 国产91在线播放九色| 国产日韩欧美综合在线| 欧美在线一级片| 成人爽a毛片一区二区免费| 激情文学亚洲色图| 久久电影国产免费久久电影| 99免费视频观看| 欧美一级网站| 黄页免费在线观看视频| 在线播放亚洲| 天堂8在线天堂资源bt| 自拍日韩欧美| 天堂av免费看| 91精品国产麻豆国产在线观看| 亚洲欧美日韩在线综合| 欧美限制电影| 日韩欧美在线电影| 欧美三级伦理在线| 婷婷四房综合激情五月| 欧美亚洲在线日韩| 日本在线播放不卡| 激情五月色综合国产精品| 免费精品视频一区二区三区| 亚洲福利网站| 久久综合九色综合网站| 亚洲欧美成人vr| 免费久久一级欧美特大黄| 蜜臀av免费一区二区三区| 美女黄毛**国产精品啪啪| 久久av免费| 日韩精品资源| 999久久久91| 综合一区中文字幕| 伊人久久大香线蕉综合四虎小说 | 99亚洲视频| 国产无套内射久久久国产| 香蕉久久夜色精品国产| 亚洲五月天综合| 久久精品国产色蜜蜜麻豆| 午夜免费看毛片| 国产一区二区免费视频| 深爱五月综合网| 成人免费视频caoporn| 91av在线免费| 中文字幕乱码久久午夜不卡 | 亚洲一区二区三区四区av| www.欧美日韩国产在线| 精品人妻互换一区二区三区| 国产拍揄自揄精品视频麻豆| 成人免费视频入口| 亚洲蜜臀av乱码久久精品| 久久亚洲成人av| 精品国产31久久久久久| 黄色大全在线观看| 3d成人h动漫网站入口| 亚洲乱码在线观看| 国产视频精品xxxx| 欧美成人xxx| 久久久久久久久久久亚洲| 在线天堂资源www在线污| 国产精品爽爽ⅴa在线观看| 日韩精品一区国产| 久久人人九九| 91精品一区二区三区综合| 免费一级特黄毛片| 久久国产精品第一页| 国产原创剧情av| 中文字幕欧美区| 国产精品9191| 欧美色爱综合网| 天堂中文在线官网| 色偷偷偷综合中文字幕;dd| 免费影视亚洲| 国产精品视频最多的网站| 加勒比色综合久久久久久久久| 日韩欧美视频一区二区| 亚洲经典视频在线观看| 黄色一级片免费的| 久久久五月婷婷| 免费在线一区二区三区| 欧美性极品少妇| 无码国产精品一区二区免费16 | 黑人极品ⅴideos精品欧美棵| 国产va免费精品高清在线| 18国产精品| 中文精品一区二区三区| 麻豆精品网站| www.美色吧.com| 亚洲欧洲一区二区在线播放| 伊人中文字幕在线观看| 亚洲国产精品小视频| av香蕉成人| 国产精品一区二区久久国产| 天美av一区二区三区久久| 久久香蕉视频网站| 精品亚洲成a人在线观看| 欧美狂猛xxxxx乱大交3| 五月婷婷激情综合网| 国产福利视频导航| 日韩在线免费观看视频| 性欧美gay| 久久99精品久久久久久久青青日本 | 欧美黑人一区二区| 日韩欧美成人激情| 黄色精品免费看| 国产精品永久免费观看| 精品国产一区二区三区av片| 久久久久久久午夜| a美女胸又www黄视频久久| 欧美成人黄色网| 欧美一级精品大片| 二区三区四区高清视频在线观看| 国产精品最新在线观看| 成人羞羞视频在线看网址| 黄色片一级视频| 久久精品欧美日韩精品| 色屁屁影院www国产高清麻豆| 亚洲精品乱码久久久久久按摩观| 欧美6一10sex性hd| 国产精品久久久对白| 亚洲图片在线| 在线免费观看污视频| 欧美日韩国产麻豆| 三级在线电影| 日韩免费在线观看视频| 国产成人短视频在线观看| 日韩在线第三页| 国产精品每日更新在线播放网址| 糖心vlog精品一区二区| 中日韩美女免费视频网站在线观看 | 亚洲综合成人网| 天天操天天操天天操| 91精品国产91久久久| 一本色道久久综合狠狠躁的番外| 青青草原av在线播放| 久久久久久久综合狠狠综合| 日韩精品在线一区二区三区| 正在播放欧美一区| 国产精品一区二区三区www| 国产精品啪啪啪视频| 国产91精品一区二区麻豆网站 | caoporn免费在线| 国产欧美综合精品一区二区| 国产精品久久777777毛茸茸 | 亚洲女人****多毛耸耸8| 亚洲成人一级片| 2019中文字幕在线观看| 国产一区二区电影在线观看| 亚洲欧美国产中文| 有码一区二区三区| 香蕉视频网站在线| 国产日韩欧美成人| 国内久久视频| 精品人妻中文无码av在线| 在线91免费看| 九色porny自拍视频在线观看| 青青草原亚洲| 国产一区二区成人久久免费影院| 国产精品111| 综合136福利视频在线| 日韩欧美久久| 成人性视频欧美一区二区三区| 亚洲欧美日韩中文播放| 天堂av一区二区三区| 国产精品女主播视频| 欧美国产日本| 免费在线观看污| 日韩欧美在线123| 日韩高清在线| 成人免费毛片在线观看| 国产精品亲子乱子伦xxxx裸| 国模无码一区二区三区| 国产又爽又黄的激情精品视频| 亚洲黄色精品| 国产免费嫩草影院| 亚洲高清av在线| 97精品资源在线观看| 红桃av在线播放| 一区二区三区欧美在线观看| 精品亚洲综合| 国产a一区二区| 精品午夜久久福利影院| 日日夜夜狠狠操|