Fescar example解析 - TC流程

简介: 开篇 这篇文章主要是梳理TC处理TM发送消息的过程,由于消息种类较多所以打算额外写篇文章分析,这篇文章主要把进入网络层以后的基本流程梳理下,方便大家阅读源码。 这篇文章的没有针对TM的接收部分进行分析,针对收到报文以后的处理流程。

开篇

 这篇文章主要是梳理TC处理TM发送消息的过程,由于消息种类较多所以打算额外写篇文章分析,这篇文章主要把进入网络层以后的基本流程梳理下,方便大家阅读源码。

 这篇文章的没有针对TM的接收部分进行分析,针对收到报文以后的处理流程。

 Transaction Coordinator (TC): 事务协调器,维护全局事务的运行状态,负责协调并驱动全局事务的提交或回滚。


TC处理时序图

TC.jpg
说明:

  • TC处理流程核心模块是DefaultCoordinator和DefaultCore。
  • DefaultCoordinator和DefaultCore的调用方式是直接方法进行调用。


TC处理流程源码分析

public class DefaultCoordinator extends AbstractTCInboundHandler
    implements TransactionMessageHandler, ResourceManagerInbound {

    private ServerMessageSender messageSender;
    private Core core = CoreFactory.get();

    public DefaultCoordinator(ServerMessageSender messageSender) {
        this.messageSender = messageSender;
        core.setResourceManagerInbound(this);
    }

    @Override
    protected void doGlobalBegin(GlobalBeginRequest request, GlobalBeginResponse response, RpcContext rpcContext) 
        throws TransactionException {
        response.setXid(core.begin(rpcContext.getApplicationId(), rpcContext.getTransactionServiceGroup(), 
                                   request.getTransactionName(), request.getTimeout()));
    }

    @Override
    protected void doGlobalCommit(GlobalCommitRequest request, GlobalCommitResponse response, RpcContext rpcContext) 
        throws TransactionException {
        response.setGlobalStatus(core.commit(XID.generateXID(request.getTransactionId())));

    }

    @Override
    protected void doGlobalRollback(GlobalRollbackRequest request, GlobalRollbackResponse response, RpcContext rpcContext) 
        throws TransactionException {
        response.setGlobalStatus(core.rollback(XID.generateXID(request.getTransactionId())));

    }

    @Override
    protected void doGlobalStatus(GlobalStatusRequest request, GlobalStatusResponse response, RpcContext rpcContext) 
        throws TransactionException {
        response.setGlobalStatus(core.getStatus(XID.generateXID(request.getTransactionId())));
    }
}

说明:

  • DefaultCoordinator提供doGlobalBegin实现事务的开启。
  • DefaultCoordinator提供doGlobalCommit实现事务的提交。
  • DefaultCoordinator提供doGlobalRollback实现事务的回滚。
  • DefaultCoordinator的Core通过CoreFactory方法获取。


public class CoreFactory {

    private static class SingletonHolder {
        private static Core INSTANCE = new DefaultCore();
    }

    public static final Core get() {
        return CoreFactory.SingletonHolder.INSTANCE;
    }

    public static void set(Core core) {
        CoreFactory.SingletonHolder.INSTANCE = core;
    }
}

说明:

  • CoreFactory提供获取DefaultCore的方法。


public class DefaultCore implements Core {

    private LockManager lockManager = LockManagerFactory.get();
    private ResourceManagerInbound resourceManagerInbound;

    public String begin(String applicationId, String transactionServiceGroup, String name, int timeout) 
    throws TransactionException {}

    @Override
    public GlobalStatus commit(String xid) throws TransactionException {}

    @Override
    public void doGlobalCommit(GlobalSession globalSession, boolean retrying) throws TransactionException {}

    private void asyncCommit(GlobalSession globalSession) throws TransactionException {}

    private void queueToRetryCommit(GlobalSession globalSession) throws TransactionException {}

    private void queueToRetryRollback(GlobalSession globalSession) throws TransactionException {}

    @Override
    public GlobalStatus rollback(String xid) throws TransactionException {}

    @Override
    public void doGlobalRollback(GlobalSession globalSession, boolean retrying) throws TransactionException {}
}

说明:

  • DefaultCore 是TC执行事务操作的核心。
  • DefaultCore 提供begin/commit/rollback等操作。
目录
相关文章
|
28天前
|
算法 数据处理 开发者
FFmpeg库的使用与深度解析:解码音频流流程
FFmpeg库的使用与深度解析:解码音频流流程
35 0
|
1月前
|
消息中间件 Unix Linux
Linux进程间通信(IPC)介绍:详细解析IPC的执行流程、状态和通信机制
Linux进程间通信(IPC)介绍:详细解析IPC的执行流程、状态和通信机制
48 1
|
1月前
|
数据采集 数据可视化 大数据
Python在数据科学中的实际应用:从数据清洗到可视化的全流程解析
Python在数据科学中的实际应用:从数据清洗到可视化的全流程解析
37 1
|
2月前
|
开发工具 数据安全/隐私保护 UED
Uniapp 微信登录流程解析
Uniapp 微信登录流程解析
53 0
|
2月前
|
安全 开发者 UED
应用商店备案登记流程解析
应用商店备案登记流程解析
|
3月前
|
监控 前端开发 测试技术
前端研发流程的深入解析:从构思到交付
前端研发流程的深入解析:从构思到交付
63 0
|
20天前
|
C++
C++ While 和 For 循环:流程控制全解析
本文介绍了C++中的`switch`语句和循环结构。`switch`语句根据表达式的值执行匹配的代码块,可以使用`break`终止执行并跳出`switch`。`default`关键字用于处理没有匹配`case`的情况。接着,文章讲述了三种类型的循环:`while`循环在条件满足时执行代码,`do/while`至少执行一次代码再检查条件,`for`循环适用于已知循环次数的情况。`for`循环包含初始化、条件和递增三个部分。此外,还提到了嵌套循环和C++11引入的`foreach`循环,用于遍历数组元素。最后,鼓励读者关注微信公众号`Let us Coding`获取更多内容。
20 0
|
2月前
|
JSON 前端开发 JavaScript
从前端到后端——Web开发的全流程解析
【2月更文挑战第2天】Web开发涉及多个方面,从前端设计到后端实现,需要开发者具备一定的技术能力和知识储备。本文将以一个简单的Web应用为例,详细介绍Web开发的全流程。
|
3月前
|
安全 Java
Java并发编程—并发流程控制与AQS原理及相关源码解析
Java并发编程—并发流程控制与AQS原理及相关源码解析
57 0
|
3月前
|
Python
Python流程控制指南:实例解析与技巧揭秘
Python流程控制指南:实例解析与技巧揭秘
24 0

推荐镜像

更多