前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Spring Batch 事务限制

Spring Batch 事务限制

原创
作者头像
HoneyMoose
发布2022-10-15 05:00:51
5500
发布2022-10-15 05:00:51
举报
文章被收录于专栏:CWIKIUSCWIKIUS

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

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

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

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

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

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

解决办法

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

2022-10-14_14-02-04
2022-10-14_14-02-04

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

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

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

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

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

https://www.ossez.com/t/spring-batch/14148

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 解决办法
相关产品与服务
批量计算
批量计算(BatchCompute,Batch)是为有大数据计算业务的企业、科研单位等提供高性价比且易用的计算服务。批量计算 Batch 可以根据用户提供的批处理规模,智能地管理作业和调动其所需的最佳资源。有了 Batch 的帮助,您可以将精力集中在如何分析和处理数据结果上。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档