CWIKIUS
  • 首页
  • 计算科学
  • 房地产
  • 文化旅游
  • 项目和网站
    • OSSEZ 计算技术
    • USRealEstate 社区
    • 地区文化
    • CWIKI.US
    • BUG.OSSEZ.COM
    • RSS.OSSEZ.COM
CWIKIUS.CN
一个有独立思考和温度的清新站
  1. Home
  2. Computer Science
  3. This article

Spring Batch 事务限制

2022年10月15日 57Browse 0Like 0Comments

对 Spring Batch 有所了解的同学都知道 Batch 是用来进行批量数据处理的。

但是我们在同时使用 Spring JPA 的时候,尤其是循环数据处理的时候,我们希望能够尽快提交事务。

但是,Spring Batch 中,如果使用了 Tasklet 的话,那么Spring 会在 Tasklet 级别创建一个事务。

在 Tasklet 不完成的情况下,事务是不会提交的。

这就需要对我们代码进行进行处理的时候,需要对数据量有多大有比较清楚的了解。

否则,非常容易遇到事务堆叠导致锁表的情况。

解决办法

针对一个 Tasklet 只完成一个特定的工作,如果 Job 的处理数据比较多的话,需要分开不同的 Tasklet 来做。

 

2022-10-14_14-02-04

 

如上图,哪怕我们在这里调用了不同的服务,调用了不同的数据层。

事务都是没有办法提交的。

简单的办法就是针对上面的操作使用不同的 Tasklet 来做。

有人问过,能不能在循环中一次一次的进行提交。

Spring Batch 这样设计的目的就是为了保持数据的完整性,因此需要对 Batch 的逻辑进行考虑,而不建议考虑怎么省事怎么来。

https://www.ossez.com/t/spring-batch/14148
Tags: None
Last updated:2022年10月15日

HoneyMoose

有温度的人文和独立的思考

Like
< Previous
Next >

Comments

Cancel reply

Categories
  • Algorithm(算法)
  • AMQP
  • Angular
  • CI
  • Compile And CI
  • Computer Science
  • Confluence
  • DataBase
  • Gradle
  • Hibernate
  • IDE
  • Java
  • Jersey
  • Jira
  • MariaDB
  • PrestaShop
  • Spring
  • Spring Batch
  • U.S.
  • U.S. Travel
  • USRealEstate
  • VisaFn

COPYRIGHT © 2020 CWIKIUS. ALL RIGHTS RESERVED.

THEME KRATOS MADE BY VTROIS

湘ICP备2020018253号-1