最近这几天玩分布式事务的,使用 atomikos ,配置好 atomikos 后再Service层添加事务注解,可是一直有个问题,注解不生效。刚开始以为表不支持事务,可看了一下表类型是InnoDB ,是支持事务的。 后来我尝试通过硬代码 jtm.getUserTransaction().begin(); 和 jtm.getUserTransaction().commit(); 却是有事务的,百思不得其接,通过网上搜索了大量资料。偶然间看到了一篇博客 ,连接如下:http://blog.youkuaiyun.com/lzw190/article/details/18989301 。该博客的一个细节引起了我的注意。就是 servlet的配置文件中不去扫描Service层注解。尝试了一下,然后解决了这个分布式事务问题。
具体代码配置如下:
web.xml 文件配置
在spring-mvc.xml文件中只扫描控制层,不扫描服务层
spring-mybatis.xml 注意是分布式数据库的配置和事务的配置。
数据库3
另外一个数据库的配置和上面相似,这里就不剪切代码了。
事务配置:
xml的配置到此结束。然后就是服务层代码了。
在方法上配置事务注解。 jtGdDao.jtaInsert();和 jtMqDao.jtaInsert(); 分别向不同的数据库表中插入数据。并保证 jtGdDao.jtaInsert(); 插入成功。jtMqDao.jtaInsert() 插入时设置主键重复机制,保证会报错
成功dao
失败dao
至此,分布式事务demo 测试结束
项目pom.xml的配置:
<dependency>
<groupId>org.atteo.moonshine</groupId>
<artifactId>atomikos</artifactId>
<version>1.2</version>
</dependency>