java分布式事务 实例_spring整合atomikos实现分布式事务的方法示例

前言

Atomikos 是一个为Java平台提供增值服务的并且开源类事务管理器,主要用于处理跨数据库事务,比如某个指令在A库和B库都有写操作,业务上要求A库和B库的写操作要具有原子性,这时候就可以用到atomikos。笔者这里整合了一个spring和atomikos的demo,并且通过案例演示说明atomikos的作用。

准备工作

开发工具:idea

数据库:mysql , oracle

正文

演示原理:通过在两个库的写操作之间人为制造异常来观察数据库是否回滚

演示步骤:1.正常写操作,观察数据库值的变化情况

2.在写操作语句之间制造异常,观察数据库值的变化情况

项目结构

5d0c7a63d67679d66ac6515e2af3e06f.png

从web.xml中可以知道,容器只加载了appliactionContext.xml,剩下的配置文件除了database.properties外都是无用文件,所以大家如果要在项目中配置的话,仅需要把appliactionContext.xml中关于atomikos的部分新增到自己项目中就OK了

appliactionContext.xml

xmlns="http://www.springframework.org/schema/beans"

xmlns:tx="http://www.springframework.org/schema/tx"

xmlns:p="http://www.springframework.org/schema/p"

xmlns:aop="http://www.springframework.org/schema/aop"

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xmlns:mvc="http://www.springframework.org/schema/mvc"

xmlns:context="http://www.springframework.org/schema/context"

xsi:schemaLocation="http://www.springframework.org/schema/beans

http://www.springframework.org/schema/beans/spring-beans-3.0.xsd

http://www.springframework.org/schema/tx

http://www.springframework.org/schema/tx/spring-tx-3.0.xsd

http://www.springframework.org/schema/aop

http://www.springframework.org/schema/aop/spring-aop-3.0.xsd

http://www.springframework.org/schema/context

http://www.springframework.org/schema/context/spring-context-3.0.xsd

http://www.springframework.org/schema/mvc

http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd">

${mysql.qa.db.url}

${mysql.qa.db.user}

${mysql.qa.db.password}

${oracle.qa.db.url}

${oracle.qa.db.user}

${oracle.qa.db.password}

classpath*:/dao/*.xml

classpath*:/daodev/*.xml

适用JUnit4进行单元测试

package com.xy.controller;

import com.xy.daodev.TransactionTestService;

import org.junit.Test;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.test.context.ContextConfiguration;

import org.springframework.test.context.junit4.AbstractJUnit4SpringContextTests;

@ContextConfiguration(locations = {"classpath:applicationContext.xml"})

public class TransactionTestMain extends AbstractJUnit4SpringContextTests {

@Autowired

private TransactionTestService transactionTestService;

/**

* 在同一事务有多个数据源

*/

@Test

public void multipleDataSource2() {

transactionTestService.updateMultipleDataSource("1","1", 100L,"1.6");

}

}

业务实现,当前没有异常操作

@Service

public class TransactionTestServiceImpl implements TransactionTestService {

@Autowired

@Qualifier("mysqlTransactionTestDao")

private MysqlTransactionTestDao mysqlTransactionTestDao;

@Autowired

@Qualifier("transactionTestDao")

private TransactionTestDao transactionTestDao;

/**

* 在同一事务有多个数据源

*/

@Override

@Transactional

public void updateMultipleDataSource(String deUserId, String inUserid, long money,String str) {

// 账户1转出操作

mysqlTransactionTestDao.decreaseMoney(deUserId, money);

//Integer.parseInt(str);

// 账户2转入操作

transactionTestDao.increaseMoney(inUserid, money);

}

}

mysql模拟金额转出,oracle模拟金额转入

UPDATE fx1 SET amount=amount - #{1,jdbcType=BIGINT} WHERE id=#{0,jdbcType=VARCHAR}

UPDATE fx1 SET amount=amount + #{1,jdbcType=BIGINT} WHERE id=#{0,jdbcType=VARCHAR}

mysql初始金额

a943b9999050b3bd572997e2bd468300.png

oracle初始金额

829e1ce69c19ea8b87353852c4b4a057.png

执行正常操作

022baa26171d3e4e478ff3562180dc9b.png

mysql当前金额

953ee18f0180396178d72fa24ccc5f52.png

oracle当前金额

385bc56a6ca68b11a81eab1c66429958.png

将被屏蔽的制造异常的代码打开

public void updateMultipleDataSource(String deUserId, String inUserid, long money,String str) {

// 账户1转出操作

mysqlTransactionTestDao.decreaseMoney(deUserId, money);

Integer.parseInt("skg");

// 账户2转入操作

transactionTestDao.increaseMoney(inUserid, money);

}

发现mysql和oracle的当前金额都没有变化,说明事务回滚成功,查看日志

f9c585b3fdd0ccfbf34131f277bfd371.png

发现控制台打印出了异常信息,并且atomikos调用了rollback()方法,从日志也证实了回滚成功。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值