关于spring事务管理 在多线程下失效的问题
spring + ibatis 环境 使用spring的aop 事务。
在 aop (service)的一个方法中,我用了多个线程,事务不起作用了,导致连接数暴增。
不用线程 可以的 。
主要是想通过多线程提高并发性,降低用户等待。
其实为什么会这样我也很清楚,
spring 的事务是通过LocalThread来保证线程安全的,事务和当前线程绑定, 搞了多个线程自然会让事务失效。
但是有个疑问,难道所有用框架的都直接抛弃掉多线程的做法吗?
别人都是如何解决这个问题的呢?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(7)
连接数暴增? 难道不控制线程数量吗? 如果是一个大任务 跑满服务器内核数就可以了吧。 如果对于单个用户,考虑不出啥业务需要启动多个线程去操作数据库,这样快吗?
请问你是用的单个线程测试还是多个线程?单个线程手动处理就行了,你所说的多线程请问是抛出了多个Thread处理业务逻辑?
只能手动开关事物了吧, 用最原始的方法
如果你的应用是web项目,可以考虑把事务绑定在request上,一次请求一次事务应该可以吧。只不过绑到request上感觉耦合太紧了。
直接在事务内另起线程是实现不了吧.
我的理解:
事物其实是用的数据库的实现,而数据库的事物是针对session(数据库)来实现的,你多线程操作数据(多个session)
刚刚自己解决掉这个问题了。
做一个handler声明为@Component。在handler里面注入Service。
在Action中注入handler,在handler起线程调用Service。
这样就达到了多线程的目的了。而且由于是在事务范围外做的线程操作,也不会有问题。
直接在事务内另起线程就不要想了,只能曲线救国。
多线程的事务……感觉这两个特性天生矛盾……事务要保持原子性,多线程一开就很难搞了啊?java不太熟,高手来解下。