1 JTA规范 Java事务API(JTA:Java Transaction API)和它的同胞Java事务服务(JTS:Java Transaction Service),为J2EE平台提供了分布式事务服务...正常情况下,一个数据库驱动供应商只需要实现JDBC规范即可,一个消息中间件供应商只需要实现JMS规范即可。...2 JTA规范接口 JTA事务模型规定了一个分布式事务中有哪些组件,而JTA接口规范则规定这些组件之间如何交互。...接口 JMS1.0规范规定支持分布式事务的JMS厂商,需要实现javax.jms.XAConnection、javax.jms.XASession接口 作为DTP模型中Application开发者的我们...可以看到,在开源版本中支持JTA/XA、JDBC、JMS的分布式事务。
: [enoepl3el2.png] 在整个事务管理过程中使用的是Spring事务控制,并且由相关ORM框架实现JPA规范 JMS事务原理 Spring JMS Session 通过Session进行事务管理操作...Session 是一个thread-bound(线程范围内) 事务上下文:一个线程一个Session Spring JMS事务类型 Session管理的事务-原生事务 外部管理的事务-JmsTransactionManager...、JTA Srping JMS事务机制过程 Session原生事务: [k7nll7dohx.png] JmsTransactionManager事务: [hbk12wzvj5.png] ##注解方式注入...:new", containerFactory = "msgFactory") public void handle(String msg) { LOG.debug("Get JMS...new", containerFactory = "msgFactory") public void handle2(String msg) { LOG.debug("Get JMS
JTA规范事务模型 Java事务API(JTA:Java Transaction API)和它的同胞Java事务服务(JTS:Java Transaction Service),为J2EE平台提供了分布式事务服务...JTA规范定义了事务管理器与其他事务参与者交互的接口,而JTS规范定义了事务管理器的实现要求,因此我们看到事务管理器底层是基于JTS的。...特别需要注意的是,并不是所有的web容器都实现了JTA规范,如tomcat并没有实现JTA规范,因此并不能提供事务管理器的功能。...正常情况下,一个数据库驱动供应商只需要实现JDBC规范即可,一个消息中间件供应商只需要实现JMS规范即可。...接口 JMS1.0规范规定支持分布式事务的JMS厂商,需要实现javax.jms.XAConnection、javax.jms.XASession接口 注意: 作为DTP模型中Application
JMS生产者接受消息,而JMS消费者确认从服务器接受消息;确认协议允许JMS提供者监测一条消息的整个过程, 以便了解是否成功的生产和消费了该消息; 消息确认 消息确认协议是保证消息传送的关键所在,JMS...从生产者角度的来看,JMS提供者为这组消息提供了高速缓存,直到执行commit()命令,如果发生了故障或者执行rollback(),这些消息会丢失; 2.事务性接收 ?...如果事务性生产者和事务性消费者由同一会话创建,那么他们就能够组合在单个事务中;这样一来,JMS客户端就可以作为单独的工作单元生产和消费消息; 4.实例分析 QSender做如下改动: ?...在接收完end结束标志之后,执行commit()方法,高速服务器接收完成;当然这里使用非事务性消费者也是可以接收消息的,事务的范围仅限于生产者或消费者与消息服务器的会话;可以发现JMS的事务和JDBC提供的事务很像...总结 本文介绍了一下JMS的消息确认模式和本地事务,并以ActiveMQ作为服务器来做测试和分析,大体上了解了JMS的确认机制;重点介绍了一下本地事务,至于分布式事务一笔带过,其实在处理分布式事务的问题
导读 JTA,即Java Transaction API,JTA允许应用程序执行分布式事务处理——在两个或多个网络计算机资源上访问并且更新数据。...JDBC驱动程序的JTA支持极大地增强了数据访问能力。 JTA是基于XA标准制定的,采用两阶段提交的方式来管理分布式事务。...即是一个事务管理器和多个资源管理器协作完成,第一阶段各个资源管理器提交,第二个阶段事务管理器需要查看资源管理器是否全部提交成功再提交。...Java实现JTA强一致性的事务有很多种实现,笔者只是选择了atomikos的实现 SpringBoot整合 添加依赖 org.springframework.boot...:JTA事务的自动配置类 关于事务的执行原理可以看看笔者之前的文章,Spring事务源码解析
spring.jta.atomikos.properties.default-jta-timeout 10000ms JTA事务的默认超时。...spring.jta.bitronix.connectionfactory.user 用于连接到JMS提供程序的用户。...如果您在相同的JMS和JDBC资源上运行事务管理器的多个实例,则应启用该功能。...spring.jta.bitronix.properties.graceful-shutdown-interval 60 TM在关闭事务之前中止事务之前等待事务完成的最大秒数。...spring.jta.enabled true 是否启用JTA支持。 spring.jta.log-dir 事务日志目录。
一、JTA组件简介 1、JTA基本概念 JTA即Java-Transaction-API,JTA允许应用程序执行分布式事务处理,即在两个或多个网络计算机资源上访问并且更新数据。...XA协议是数据库层面的一套分布式事务管理的规范,JTA是XA协议在Java中的实现,多个数据库或是消息厂商实现JTA接口,开发人员只需要调用SpringJTA接口即可实现JTA事务管理功能。...JTA事务比JDBC事务更强大。一个JTA事务可以有多个参与者,而一个JDBC事务则被限定在一个单一的数据库连接。...JTA规范定义了事务管理器与其他事务参与者交互的接口,其他的事务参与者与事务管理器进行交互。 二、SpringBoot整合JTA 项目整体结构图 ? 1、核心依赖 JTA组件来统一管理,方便事务的通信。
对于只操作单一数据源的应用,可以通过本地资源接口实现事务管理;对于跨数据源(例如多个数据库,或者数据库与 JMS)的大型应用,则必须使用全局事务 JTA (Java Transaction API)。...若确实需要分布式事务以协调多个事务资源,则应实现和配置所支持 XA 协议的事务资源,如 JMS、JDBC 数据库连接池等。...正是基于统一规范的不同实现使得 JTA 可以协调与控制不同数据库或者 JMS 厂商的事务资源,其架构如下图所示: ?...上述示例演示了 JTA 事务的处理过程,下面将为您展示事务资源(数据库连接,JMS)是如何以透明的方式加入到 JTA 事务中的。...,定义了分布式事务处理过程中事务管理器和资源管理器之间的协议,各事务资源提供商(如 JDBC 驱动,JMS)将提供此接口的实现。
38.3使用Java EE托管事务管理器 如果将Spring Boot应用程序打包为 war 或 ear 文件并将其部署到Java EE应用程序服务器,则可以使用应用程序服务器的内置事务管理器。...如果使用应用程序服务器提供的事务服务,通常还需要确保所有资源都由服务器管理并通过JNDI公开。...38.4混合XA和非XA JMS连接 使用JTA时,主JMS ConnectionFactory bean可识别XA并参与分布式事务。...在某些情况下,您可能希望使用非XA ConnectionFactory 处理 某些JMS消息。例如,您的JMS处理逻辑可能需要比XA超时更长的时间。...如果您 在 ApplicationContext 中注册了 JtaTransactionManager bean和相应的XA包装beans,则DataSource和JMS自动配置将使用JTA变体。
spring.jta.atomikos.properties.default-jta-timeout = 10000 #JTA事务的默认超时。...spring.jta.bitronix.connectionfactory.user =#用于连接到JMS提供者的用户。...spring.jta.bitronix.properties.debug零资源事务 =假#日志的创建和提交没有一个单一的士兵资源执行的事务调用堆栈。...spring.jta.narayana.recovery-jms-pass = #恢复管理器使用的JMS密码。...spring.jta.narayana.recovery-jms-user = #恢复管理器使用的JMS用户名。
监听新订单队列中的消息,获取之后新增订单,成功则往新订单缴费队列中写消息,中间新增订单的过程使用JTA事务管理,当新增失败则事务回滚,不会往新订单缴费队列中写消息; 再比如User service 扣费成功后...Spring JTA分布式事务实现 可以使用如JBoss之类的应用服务器提供的JTA事务管理器 可以使用Atomikos、Bitronix等库提供的JTA事务管理器 不使用Spring JTA的分布式事务实现...最大努力一次提交 依次提交事务 可能出错 通过AOP或Listener实现事务直接的同步 JMS最大努力一次提交+重试 适用于其中一个数据源是MQ,并且事务由读MQ消息开始 利用MQ消息的重试机制 重试的时候需要考虑重复消息...链式事务管理 定义一个事务链 多个事务在一个事务管理器里依次提交 可能出错 如何选择(根据一致性要求) 强一致性事务:JTA(性能最差、只适用于单个服务内) 弱、最终一致性事务:最大努力一次提交、链式事务...不处理重试 基于实例1的核心代码继续做修改演示: git代码地址 ☚ 实例4-JMS-DB.最大努力一次提交 JMS-DB ActiveMQ + Mysql 最大努力一次提交:TransactionAwareConnectionFactoryProxy
38.使用JTA的分布式事务 Spring Boot通过使用Atomikos或Bitronix 嵌入式事务管理器支持跨多个XA资源的分布式JTA事务。...部署到合适的Java EE Application Server 时,也支持JTA事务。 检测到JTA环境时,Spring的 JtaTransactionManager 用于管理事务。...自动配置的JMS,DataSource和JPA beans已升级为支持XA事务。您 可以使用标准Spring惯用语(例如 @Transactional )来参与分布式事务。...如果您在JTA环境中并且仍想使用本地事务,则可以 将 spring.jta.enabled 属性设置为 false 以禁用JTA自动配置。...38.2使用Bitronix事务管理器 Bitronix是一种流行的开源JTA事务管理器实现。
JDBC是可以用来访问不同关系数据库的API,而JMS则提供同样与厂商无关的访问消息收发服务的方法,这样就可以通过消息收发服务实现从一个JMS客户机向另一个JMS客户机发送消息,所需要的是厂商支持JMS...10、JTA(JavaTransaction API):Java事务API 定义了一种标准API,应用程序由此可以访问各种事务监控。...它允许应用程序执行分布式事务处理--在两个或多个网络计算机资源上访问并且更新数据。JTA和JTS为J2EE 平台提供了分布式事务服务。 ...JTA事务比JDBC事务更强大,一个JTA事务可以有多个参与者,而一个JDBC事务则被限定在一个单一的数据库连接。 Java 事务API 可以横跨的包含:EJB訪问、JDBC连接以及JMS连接。...JTS指定了一个事务管理器的实现(Transaction Manager),这个管理器在一个高级别上支持JTA规范,并且在一个低级别上实现了OMGOTS规范的Java映射。
如果这两条数据在一个数据库中,那么通过之前介绍的事务管理就能轻松解决了。但是,当这两个操作位于不同的数据库中,那么就无法实现了。 本文就来介绍一种解决这类问题的方法:JTA事务。...什么是JTA JTA,全称:Java Transaction API。JTA事务比JDBC事务更强大。一个JTA事务可以有多个参与者,而一个JDBC事务则被限定在一个单一的数据库连接。...所以,当我们在同时操作多个数据库的时候,使用JTA事务就可以弥补JDBC事务的不足。...动手试试 下面我们就来实操一下,如何在Spring Boot中使用JTA来实现多数据源下的事务管理。...JTA事务生效,保证了test1和test2两个库中的User表数据更新一致,没有制造出脏数据。
Java消息服务(java Message Service,JMS)是一个Java标准,定义了使用消息代理的通用API。...在JMS出现之前,每个消息代理都有私有的API,这就使得不同代理之间的消息代码很难通用。但是借助JMS,所有遵从规范的实现都使用通用的接口。...spring通过基于模板的抽象为JMS功能提供了支持,这个模板也就是JmsTemplate,使用JmsTemplate,能够非常容易地在消息生产方发送队列和主题消息,在消费消息的那一方,也能够非常容易地接收这些消息
基于MQ,JTA实现多服务的分布式事务 Orderservice监听新订单队列中的消息,获取之后新增订单,成功则往新订单缴费队列中写消息,中间新增订单的过程使用JTA事务管理,当新增失败则事务回滚,不会往新订单缴费队列中写消息...使用 Spring JTA 可以使用 如JBoss之类的应用服务器提供的JTA事务管理器 Atomikos、Bitronix等库提供的JTA事务管理器 禁止使用JTA 为什么禁用JTA ?...那既然不使用 JTA,如何实现事务呢?...MQ 事务尚未提交,所以可直接回滚。这也就是不使用 JTA 时遇到的最大难题。...1.4 JMS最大努力一次提交+重试 适用场景 其中一个数据源是MQ,并且事务由读MQ消息开始。 利用MQ消息的重试机制,重试的时候需要考虑重复消息。
9、JMS(Java Message Service)Java 消息服务 JMS是Java的消息服务,JMS的客户端之间可以通过JMS服务进行异步的消息传输。...JMS用于和面向消息的中间件相互通信的应用程序接口(API)。...10、JTA(Java Transaction API)Java 事务 API 在JavaEE应用中,事务是一个不可或缺的组件模型,它保证了用户操作ACID(即原子、一致、隔离、持久)属性。...对于那些跨数据源(例如多个数据库,或者数据库与JMS)的大型应用,则必须使用全局事务JTA。...应用系统可以由JTA定义的标准API访问各种事务监控,JTA为JavaEE平台提供了分布式事务服务,它隔离了事务与底层的资源,实现了透明的事务管理方式。
spring.jta.bitronix.connectionfactory.allow-local-transactions = true #事务管理器是否允许混合XA和非XA事务。...spring.jta.bitronix.connectionfactory.password = #用于连接到JMS提供程序的密码。...spring.jta.bitronix.connectionfactory.user = #用于连接到JMS提供者的用户。...spring.jta.bitronix.datasource.allow-local-transactions = true #事务管理器是否允许混合XA和非XA事务。...spring.jta.bitronix.datasource.defer-connection-release = true #数据库是否可以在同一连接上运行许多事务,并支持事务交织。
JMS提供了相似这种功能,本章我们将系统的学习JMS中的相关重要内容。...用JMS编写的程序能够在不论什么实现JMS标准的MOM上执行。 JMS可移植性的关键在于:JMS API是由Sun作为一组接口而提供的。...提供了JMS功能的产品是通过提供一个实现这些接口的提供者来做到这一点的。开发者能够通过定义一组消息和一组交换这些消息的应用程序,建立JMS应用程序,实现异步通讯。...JMS的目标 JMS从提出以来,致力于完毕例如以下几个目标: 定义一组消息公用概念和有用工具。...JMS两种消息模型 JMS提供了两种消息通信模型: Ø 点到点(P2P)模型 Ø 公布/订阅(Pub/Sub)模型 图 2 JMS通讯模型 从图中能够看出,ClientA和ClientB
领取专属 10元无门槛券
手把手带您无忧上云