为了账号安全,请及时绑定邮箱和手机立即绑定

处理循环的 EJB 事务超时

处理循环的 EJB 事务超时

慕侠2389804 2022-06-15 10:44:27
我有一种处理大量文件的方法。问题是当文件大小增加时,此方法将超时。我正在为该方法使用容器管理的事务。我所做的是将文件拆分为列表,并提供以另一种装饰为@REQUIRES_NEW 的方法进行操作。我正在使用新事务遍历列表中的新方法。但是当在迭代中间发生某些事情时,只有事务才会回滚。它不会回滚以前的迭代。我也想回滚以前的迭代。由于超时问题,我不能将整个操作视为一个操作。寻找对此的反馈。
查看完整描述

2 回答

?
MMMHUHU

TA贡献1834条经验 获得超8个赞

检查是否增加您的 ejb 方法的事务超时,例如,如果您使用无状态 bean,您可以简单地注释

 @StatelessDeployment(transactionTimeout=10)

另一种选择是,检查EJB 异步方法

https://docs.oracle.com/javaee/6/tutorial/doc/gkkqg.html

异步方法通常用于长时间运行的操作、处理器密集型任务、后台任务、增加应用程序吞吐量或改善应用程序响应时间。流程结束后,您可以获取流程的状态。


查看完整回答
反对 回复 2022-06-15
?
慕桂英3389331

TA贡献2036条经验 获得超8个赞

您可能会考虑以下方法:当客户端请求文件处理(startProcessing)时,服务器(EJB)启动后台线程(例如quartz-scheduler.org)来处理文件并返回正在进行的操作的id。如果需要,客户端可以使用这样的 id 取消处理、获取处理状态等。



查看完整回答
反对 回复 2022-06-15
  • 2 回答
  • 0 关注
  • 112 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信