ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

seata源码解析:seata是如何支持TCC模式的?

2021-10-06 00:00:31  阅读:260  来源: 互联网

标签:VARCHAR seata prepare TCC 源码 branch table id gmt


请添加图片描述

介绍

增加了横切逻辑实现类

一阶段开启分支事务

TccActionInterceptor

二阶段提交/回滚分支事务

DefaultCore#commit
TCCResourceManager#branchCommit

CREATE TABLE IF NOT EXISTS `global_table`
(
    `xid`                       VARCHAR(128) NOT NULL,
    `transaction_id`            BIGINT,
    `status`                    TINYINT      NOT NULL,
    `application_id`            VARCHAR(32),
    `transaction_service_group` VARCHAR(32),
    `transaction_name`          VARCHAR(128),
    `timeout`                   INT,
    `begin_time`                BIGINT,
    `application_data`          VARCHAR(2000),
    `gmt_create`                DATETIME,
    `gmt_modified`              DATETIME,
    PRIMARY KEY (`xid`),
    KEY `idx_gmt_modified_status` (`gmt_modified`, `status`),
    KEY `idx_transaction_id` (`transaction_id`)
) ENGINE = InnoDB
  DEFAULT CHARSET = utf8;

-- the table to store BranchSession data
CREATE TABLE IF NOT EXISTS `branch_table`
(
    `branch_id`         BIGINT       NOT NULL,
    `xid`               VARCHAR(128) NOT NULL,
    `transaction_id`    BIGINT,
    `resource_group_id` VARCHAR(32),
    `resource_id`       VARCHAR(256),
    `branch_type`       VARCHAR(8),
    `status`            TINYINT,
    `client_id`         VARCHAR(64),
    `application_data`  VARCHAR(2000),
    `gmt_create`        DATETIME(6),
    `gmt_modified`      DATETIME(6),
    PRIMARY KEY (`branch_id`),
    KEY `idx_xid` (`xid`)
) ENGINE = InnoDB
  DEFAULT CHARSET = utf8;

-- the table to store lock data
CREATE TABLE IF NOT EXISTS `lock_table`
(
    `row_key`        VARCHAR(128) NOT NULL,
    `xid`            VARCHAR(128),
    `transaction_id` BIGINT,
    `branch_id`      BIGINT       NOT NULL,
    `resource_id`    VARCHAR(256),
    `table_name`     VARCHAR(32),
    `pk`             VARCHAR(36),
    `gmt_create`     DATETIME,
    `gmt_modified`   DATETIME,
    PRIMARY KEY (`row_key`),
    KEY `idx_branch_id` (`branch_id`)
) ENGINE = InnoDB
  DEFAULT CHARSET = utf8;

global_table

172.21.0.14:18091:6449338273221152788,6449338273221152788,1,seata-tcc-tm,my_test_tx_group,“transfer(java.lang.String, java.lang.String, java.lang.Integer)”,60000,1633261303962,2021-10-03 19:41:43,2021-10-03 19:41:43

branch_table

6449338273221152790,172.21.0.14:18091:6449338273221152788,6449338273221152788,prepare,TCC,0,seata-tcc-tm:219.238.205.162:30726,"{"“actionContext”":{"“action-start-time”":1633261303972,"“money”":200,"“sys::prepare”":"“prepare”","“fromUserId”":"“1001"”,"“sys::rollback”":"“cancel”","“sys::commit”":"“commit”","“host-name”":"“192.168.97.57"”,"“toUserId”":"“1002"”,"“actionName”":"“prepare”"}}",2021-10-03 19:41:43,2021-10-03 19:41:43

6449338273221152792,172.21.0.14:18091:6449338273221152788,6449338273221152788,prepare,TCC,0,seata-tcc-rm:219.238.205.162:30537,"{"“actionContext”":{"“action-start-time”":1633261304008,"“money”":200,"“sys::prepare”":"“prepare”","“fromUserId”":"“1001"”,"“sys::rollback”":"“cancel”","“sys::commit”":"“commit”","“host-name”":"“192.168.97.57"”,"“toUserId”":"“1002"”,"“actionName”":"“prepare”"}}",2021-10-03 19:41:44,2021-10-03 19:41:44

参考博客

[1]https://blog.csdn.net/zjj2006/article/details/108959939
[2]https://zhuanlan.zhihu.com/p/271735569

标签:VARCHAR,seata,prepare,TCC,源码,branch,table,id,gmt
来源: https://blog.csdn.net/zzti_erlie/article/details/120595323

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有