Narayana 事务 begin 流程

2023-12-08 11:28
文章标签 流程 事务 begin narayana

本文主要是介绍Narayana 事务 begin 流程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Narayana 事务 begin 流程

整体流程

检查事务状态
获取超时时间
创建事务对象事务对象设置到 ThreadLocal 中,和当前线程绑定

使用 API

TransactionManager transactionManager = jtaPropertyManager.getJTAEnvironmentBean().getTransactionManager();
// 开启全局事务
transactionManager.begin();

调用链路

internal.jta.transaction.arjunacore.BaseTransaction#begin
开启事务internal.jta.transaction.arjunacore.BaseTransaction#checkTransactionState校验事务状态jta.common.JTAEnvironmentBean#isXaTransactionTimeoutEnabled是否启用超时配置internal.jta.transaction.arjunacore.TransactionImple#getTransaction获取当前线程已经存在的全局事务arjuna.coordinator.BasicAction#Currentinternal.arjuna.thread.ThreadActionData#currentActioninternal.arjuna.thread.ThreadActionData#setup如果当前事务存在,执行setup操作arjuna.coordinator.TxControl#createTransactionStatusManager 静态代码块创建 TransactionStatusManagerarjuna.recovery.TransactionStatusManager#start启动事务状态管理arjuna.recovery.TransactionStatusManager#getTsmServerSocketarjuna.recovery.TransactionStatusManager#getListenerHostNamearjuna.common.RecoveryEnvironmentBean#getTransactionStatusManagerAddressarjuna.utils.Utility#hostNameToInetAddressarjuna.recovery.TransactionStatusManager#addServicearjuna.common.RecoveryEnvironmentBean#isTimeoutSocketinternal.arjuna.recovery.TransactionStatusManagerItem#createAndSave创建 status manager item 并序列化保存arjuna.utils.Utility#getProcessUid创建 uid,由 hostInetAddr + pid + hash 组成internal.arjuna.recovery.TransactionStatusManagerItem#saveThis将 host+port 写出到存储日志arjuna.state.OutputBuffer#initBufferarjuna.utils.Utility#hostInetAddrarjuna.utils.Utility#getpidarjuna.common.Uid#generateHashinternal.arjuna.recovery.TransactionStatusManagerItem#save_state保存状态到磁盘arjuna.state.OutputBuffer#packString打包状态到 outputBufferinternal.arjuna.recovery.TransactionStatusManagerItem#getStore反射获取存储实例并初始化internal.arjuna.objectstore.FileSystemStore#write_committed写出buffer里的状态到文件存储internal.arjuna.objectstore.FileSystemStore#write_state_internalinternal.arjuna.objectstore.ShadowingStore#write_state写出状态到磁盘internal.arjuna.objectstore.FileSystemStore#synchronousWrites同步写,调用 sync 刷盘internal.arjuna.objectstore.FileSystemStore#closeAndUnlock解锁internal.arjuna.objectstore.FileSystemStore#addToCache写出结果缓存到内存new TransactionImple(v)创建事务对象arjuna.AtomicAction#begin开启事务arjuna.coordinator.TwoPhaseCoordinator#startarjuna.coordinator.BasicAction#Current获取当前 BasicActionarjuna.coordinator.TwoPhaseCoordinator#startarjuna.coordinator.BasicAction#BeginBasicAction 开启事务操作arjuna.StateManager#get_uidarjuna.coordinator.BasicAction#actionInitialisearjuna.coordinator.ActionHierarchy#addarjuna.coordinator.ActionManager#managerarjuna.coordinator.ActionManager#putinternal.arjuna.thread.ThreadActionData#pushAction缓存创建的 BasicAction 事务对象 到 当前线程internal.jta.transaction.arjunacore.TransactionImple#putTransaction缓存 TransactionImple 到 hashMap,key是uid

这篇关于Narayana 事务 begin 流程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/469673

相关文章

Spring Boot 中的默认异常处理机制及执行流程

《SpringBoot中的默认异常处理机制及执行流程》SpringBoot内置BasicErrorController,自动处理异常并生成HTML/JSON响应,支持自定义错误路径、配置及扩展,如... 目录Spring Boot 异常处理机制详解默认错误页面功能自动异常转换机制错误属性配置选项默认错误处理

Spring Boot从main方法到内嵌Tomcat的全过程(自动化流程)

《SpringBoot从main方法到内嵌Tomcat的全过程(自动化流程)》SpringBoot启动始于main方法,创建SpringApplication实例,初始化上下文,准备环境,刷新容器并... 目录1. 入口:main方法2. SpringApplication初始化2.1 构造阶段3. 运行阶

使用Go实现文件复制的完整流程

《使用Go实现文件复制的完整流程》本案例将实现一个实用的文件操作工具:将一个文件的内容完整复制到另一个文件中,这是文件处理中的常见任务,比如配置文件备份、日志迁移、用户上传文件转存等,文中通过代码示例... 目录案例说明涉及China编程知识点示例代码代码解析示例运行练习扩展小结案例说明我们将通过标准库 os

Ubuntu 24.04启用root图形登录的操作流程

《Ubuntu24.04启用root图形登录的操作流程》Ubuntu默认禁用root账户的图形与SSH登录,这是为了安全,但在某些场景你可能需要直接用root登录GNOME桌面,本文以Ubuntu2... 目录一、前言二、准备工作三、设置 root 密码四、启用图形界面 root 登录1. 修改 GDM 配

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

Spring Security中用户名和密码的验证完整流程

《SpringSecurity中用户名和密码的验证完整流程》本文给大家介绍SpringSecurity中用户名和密码的验证完整流程,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 首先创建了一个UsernamePasswordAuthenticationTChina编程oken对象,这是S

Android ViewBinding使用流程

《AndroidViewBinding使用流程》AndroidViewBinding是Jetpack组件,替代findViewById,提供类型安全、空安全和编译时检查,代码简洁且性能优化,相比Da... 目录一、核心概念二、ViewBinding优点三、使用流程1. 启用 ViewBinding (模块级

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c

MySQL 事务的概念及ACID属性和使用详解

《MySQL事务的概念及ACID属性和使用详解》MySQL通过多线程实现存储工作,因此在并发访问场景中,事务确保了数据操作的一致性和可靠性,下面通过本文给大家介绍MySQL事务的概念及ACID属性和... 目录一、什么是事务二、事务的属性及使用2.1 事务的 ACID 属性2.2 为什么存在事务2.3 事务