本文来说下分布式事务中间件seata
seata下载
Seata是一个分布式事务中间件,使用它必须要启动服务,然后微服务中的服务,也就是Seata的客户端会向Seata的服务端进行注册,注册的时候会有携带该客户端的一些相关信息,具体是什么后面我们会说到。
到官网上下载seata,最新的版本是1.4.2,下载二进制版本的
下载完毕之后解压,我这里下载的是1.4.0版本。在github上下载有时候会比较慢。
修改file.conf的配置
这里说一下Seata服务端数据的存储模式,目前是支持两种一种是数据库db,一种是文件file,默认是使用的文件,但是个人觉得最好还是使用数据库会好一点。Seata的全局事务会话信息由3部分内容组成,全局事务、分支事务、全局锁,它们对应的表名分别为global_table、branch_table、lock_table。
1.0版本之后里面没有这些sql文件,只有1.0以下的才有。下面我们创建Seata服务端需要的数据库seata和表,建表脚本如下:
-- -------------------------------- The script used when storeMode is 'db' --------------------------------
-- the table to store GlobalSession data
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_status_gmt_modified` (`status` , `gmt_modified`),
KEY `idx_transaction_id` (`transaction_id`)
) ENGINE = InnoDB
DEFAULT CHARSET = utf8mb4;
-- 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 = utf8mb4;
-- 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),
`status` TINYINT NOT NULL DEFAULT '0' COMMENT '0:locked ,1:rollbacking',
`gmt_create` DATETIME,
`gmt_modified` DATETIME,
PRIMARY KEY (`row_key`),
KEY `idx_status` (`status`),
KEY `idx_branch_id` (`branch_id`)
) ENGINE = InnoDB
DEFAULT CHARSET = utf8mb4;
CREATE TABLE IF NOT EXISTS `distributed_lock`
(
`lock_key` CHAR(20) NOT NULL,
`lock_value` VARCHAR(20) NOT NULL,
`expire` BIGINT,
primary key (`lock_key`)
) ENGINE = InnoDB
DEFAULT CHARSET = utf8mb4;
INSERT INTO `distributed_lock` (lock_key, lock_value, expire) VALUES ('HandleAllSession', ' ', 0);
在seata1.0以后,可以下载seata的源码,得到上面的sql脚本,路径如下所示
之后就是修改Seata的配置文件,打开解压后的目录,并进入到conf目录,这里主要是Seata的配置文件,分别是registry.conf和file.conf,这两个文件主要是配置服务端配置的相关信息,因为默认使用的注册类型是file(其他有nacos、eureka、redis等),即会从file.conf读取相关配置。我们接下来就是修改file.conf,修改存储模式为db,并配置db的相关信息,如下:
修改registry.conf的配置
在registry模块中将type选择为nacos 并且在nacos中的serverAddr修改成localhost:8848 这是我们的nacos注册进的地址
启动Seata
启动Seata,双击下面的bat命令来启动seata
nocas控制面板查看seata服务是否启动成功,成功注册进入nocas中