JTA事务管理
何为分布式事务
一个事务包含多个操作,多个操作操作了多个数据源,这样的事务称为分布式事务
和普通事务的区别
单一数据源,事务管理可以借助数据源本地事务完成,实现简单
分布式事务之困难:不可简单的借助数据源本地事务完成
为什么:
但是这样的事务有保障吗?
1、提交时,db1提交成功,db2网络不通
2、提交时con1提交完成,此时应用重启了或者应用及其断电了
分布式事务管理需要什么?
分布式事务管理需要:
1协调各数据源提交、回滚、以及应对通信异常的管理机制
2数据源需要支持这种机制
3应对应用恢复的机制
从上面可以得出,做分布式事务管理需要的参与者
如果是这样,那么
1 事务管理器协调数据源,两者之间需要通信,并需要一套协议规范
2为应对网络,主机故障等,事务管理器,数据源需要记录相关的事务日志
何为XA规范
X/Open(The open group)提出的分布式事务处理规范,分布式事务处理的工业标准
XA-DTP
X/Open Distributed Transaction Processing(DTP)model分布式事务处理模型
XA-流程
XA-两阶段提交
JTA是什么?
JTA: Java Transaction Api
Java 根据XA规范提出的事务处理规范
目的:同意API,简化程序员的学习,简化编程
JTA-API-构成
面向TM、RM提供商的API:
面向编程者的API:
UserTransaction
Jta-tm实现提供商
JavaEE应用服务器内建JTA事务管理(TM),提供商:
Weblogic,websphere
开源、独立的JTA事务管理器(TM)组件:
Java Open Transaction Manager(JOTM)
JBoss TS
Bitronix Transaction Manager(BTM)
Atomikos
Narayana
Jta-rm实现提供商
在连接池组件中一般也会提供包装实现:
Spring中应用JTA
Spring 自身并未提供jta TM实现,但提供了很好的集成
根据TM的提供者不通,分为两种应用方式
方式一:使用JavaEE服务器内建的TM,用法做如下配置即可
或
说明:JtaTransactionManager通过JNDI找到服务器提供的java:comp/UserTransaction,
java:comp/TransactionManager
应用使用的数据源需是支持xa的数据源
方式二:在没有实现TM的应用服务器上(Tomcat,jetty),将独立的TM组件集成到
我们的应用中
一:使用轻量级服务器+集成TM组件
二:使用轻量级服务器+集成TM组件
1、引入TM组件的jar(以Atomikos为例)
2、配置数据源,一定要是XA数据源
3、配置事务管理器TM
TransactionManager的实现bean
UserTransaction的实现bean
spring的JtaTransactionManager(注入TM、UserTransaction)
准备两个数据源
JTA事务管理的更多相关文章
- JTA事务管理--配置剖析(二)
Spring引用Tomcat的 JTA事务 Tomcat是Servlet容器,但它提供了JNDI的实现,因此用户可以象在Java EE应用程序服务器中一样,在Tomcat中使用JNDI查找JD ...
- JTA事务管理--配置剖析
概述 [IT168 专稿]Spring 通过AOP技术可以让我们在脱离EJB的情况下享受声明式事务的丰盛大餐,脱离Java EE应用服务器使用声明式事务的道路已经畅通无阻.但是很大部分人都还认为 ...
- springboot多数据源+jta事务管理配置
1.创建一个maven项目,导入相关配置: <?xml version="1.0" encoding="UTF-8"?> <project x ...
- Spring+JTA+Atomikos+mybatis分布式事务管理
我们平时的工作中用到的Spring事务管理是管理一个数据源的.但是如果对多个数据源进行事务管理该怎么办呢?我们可以用JTA和Atomikos结合Spring来实现一个分布式事务管理的功能.了解JTA可 ...
- hibernate事务管理 (jdbc jta)
hibernate的两种事务管理jdbc 和jta方式.下边说说两者的区别一.说明一下jdbc和jta方式事务管理的区别:JDBC事务由Connnection管理,也就是说,事务管理实际上是在JDBC ...
- atomikos实现多数据源支持分布式事务管理(spring、tomcat、JTA)
原文链接:http://iteye.blog.163.com/blog/static/1863080962012102945116222/ Atomikos TransactionsEssenti ...
- SpringBoot2 整合JTA组件,多数据源事务管理
本文源码:GitHub·点这里 || GitEE·点这里 一.JTA组件简介 1.JTA基本概念 JTA即Java-Transaction-API,JTA允许应用程序执行分布式事务处理,即在两个或多个 ...
- Spring事务管理(转)
1 初步理解 理解事务之前,先讲一个你日常生活中最常干的事:取钱. 比如你去ATM机取1000块钱,大体有两个步骤:首先输入密码金额,银行卡扣掉1000元钱:然后ATM出1000元钱.这两个步骤必须是 ...
- Hibernate 事务管理
一. 事务包含四个基本特性:简称ACID: 1. Atomic(原子性):全部成功或全部失败: 2. Consistency(一致性):只有合法数据才能被写入,不合法则回滚到最初状态: 3. Isol ...
随机推荐
- Java判断当前时间是否在某一时间段内
今天有一个任务,判断现在的时间是否在某一个时间段内 遇到的第一个问题 Date类获取日期时间大的方法失效了 问题描述: 在学习Date类时,习惯性的用get方法调用Date()的年月日,发现不怎么好用 ...
- spark提交jar包时出现unsupported major.minor version 52.0错误的解决方案
一.问题: 最近在spark集群上做一个项目,打包提交jar包时,出现了unsupported major.minor version 52.0的报错,而在local模式运行却能正常运行! 二.错误原 ...
- SQL求几何重心
ST_Centroid(geometry); geometry :a specified ST_Geometry e.g.: select ST_AsText(ST_Centroid('0103000 ...
- 阶段01Java基础day25网络编程
26.01_网络编程(网络编程概述) A:计算机网络 是指将地理位置不同的具有独立功能的多台计算机及其外部设备,通过通信线路连接起来,在网络操作系统,网络管理软件及网络通信协议的管理和协调下,实现资源 ...
- SharePoint Framework 基于团队的开发(二)
博客地址:http://blog.csdn.net/FoxDave 本篇介绍SPFx项目的一般开发流程.SharePoint Framework基于开源的工具链,也遵循开源技术栈中其他项目的开发流程. ...
- C#中委托的同步和异步有什么区别
通过定义委托,来实现同步和异步,委托通过Action和Func来实现,记录学习委托的同步和异步的过程 委托的同步方法 委托的Invoke方法用来进行同步调用. static void Main(str ...
- Swing学习2——图标添加Icon接口使用
废话没有,看代码. 主要就是通过实现Icon接口在标签添加一个圆形图标,并在框架中显示. package com.sword.swing_test; import javax.swing.*; imp ...
- makefile笔记1 - 初识makefile
前情提要 上一篇<编译入门>讲了变成的基本问题.如果源文件只有一个,就如之前的例子,那么用gcc命令直接编译就可以了.但是很多实际的工程用到的源文件都是相当多的,这时候用命令一个个编译是很 ...
- readfile() file_get_content f
php.ini:memory_limit memory_limit是设置内存限制的,如果使用readfile()读取文件就会和这个有关, 调用readfile()函数将打开这个文件,并且将文件内容输出 ...
- Mysql 大量Sleep 解决
排查 SHOW GLOBAL VARIABLES LIKE 'wait_timeout'; SHOW GLOBAL VARIABLES LIKE 'interactive_timeout'; 在线更新 ...