利用spring实现多线程 + 事务回滚

利用spring实现多线程 + 事务回滚,第1张

利用线程池和CountDownLatch,多线程并发处理批量数据,实现多线程事务回滚,事务补偿。

begin设置为1,用于发布开始命令,如果需要开始,则begin.countdown

end用于记录任务的执行情况。begin.countdown后,需end.await,等待任务都执行完。

当begin.countdown开始执行任务后,在最后需end.countdown

当end.countdown减到为0后,则切换到主线程,继续开始往下执行

实现更灵活的去配置各业务数据 *** 作场景,即:暴露excute方法执行线程任务,执行的具体执行任务交给回调函数实现。

基于spring上下文中获取事务管理器

封装获取spring上下文工具类

ApplicationContextProvider

实现springMVC的多线程并发:

1、ThreadLocal为解决多线程程序的并发问题提供了一种新的思路

2、对于多线程资源共享的问题,同步机制采用了“以时间换空间”的方式,而ThreadLocal采用了“以空间换时间”的方式。前者仅提供一份变量,让不同的线程排队访问,而后者为每一个线程都提供了一份变量,因此可以同时访问而互不影响。

Spring MVC属于SpringFrameWork的后续产品,已经融合在Spring Web Flow里面。

Spring 框架提供了构建 Web 应用程序的全功能 MVC 模块。

使用 Spring 可插入的 MVC 架构,可以选择是使用内置的 Spring Web 框架还可以是 Struts 这样的 Web 框架。

Spring aop 依赖注入的就是单例对象,我们在使用的时候如果有多个相同处理且不怎么耗时的情况下一般会采用for循环直接执行,这样的情况下即使有事务管理也不会影响业务执行下去;但是,大多数的应用比如:系统与系统之间的交互就比较耗时了,此时使用for循环执行业务就不可取了,于是我们想用线程来解决这个问题。

另外,附带说明一下:如果是在Spring提供的@Test下测试:如果有多线程处理,需要调用Thread.sleep(3000)实现线程等待,这也是测试多线程模式下所必须的。如果不加线程休眠,不等待多线程执行完毕,很有可能测不出来多线程调用的处理。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10646500.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-10
下一篇 2023-05-10

发表评论

登录后才能评论

评论列表(0条)

保存