微服务高级篇【2】之Seata部署

文章目录

  • Seata的部署和集成
    • 1. Seata下载[Seata1.6.1](https://github.com/seata/seata/releases/tag/v1.6.1)
    • 2. Seata解压
    • 3. 修改Seata配置
    • 4. nacos中新增配置
    • 5. 创建数据库表
    • 6. 启动TC服务

Seata的部署和集成

微服务高级篇【2】之Seata部署_第1张图片

1. Seata下载Seata1.6.1

微服务高级篇【2】之Seata部署_第2张图片

2. Seata解压

微服务高级篇【2】之Seata部署_第3张图片

3. 修改Seata配置

  • 修改conf目录下的registry.conf文件:
    微服务高级篇【2】之Seata部署_第4张图片
    seata:
      config:
        # support: nacos, consul, apollo, zk, etcd3
        # 读取tc服务端的配置文件的方式,这里是从nacos配置中心读取,这样如果tc是集群,可以共享配置
        type: nacos
        # 配置nacos地址等信息
        nacos:
          serverAddr: 127.0.0.1:8848
          namespace: ""
          group: SEATA_GROUP
          username: nacos
          password: nacos
          dataId: seataServer.properties
      registry:
        # support: nacos, eureka, redis, zk, consul, etcd3, sofa
        # tc服务的注册中心类,这里选择nacos,也可以是eureka、zookeeper等
        type: nacos
        nacos:
          # seata tc 服务注册到 nacos的服务名称,可以自定义
          application: seata-tc-server
          serverAddr: 127.0.0.1:8848
          group: DEFAULT_GROUP
          namespace: ""
          cluster: SH
          username: nacos
          password: nacos
    
    • 注意:nacos中需要创建命名空间,id为 上图中的 seata-namespace-id , 名称 为 seata,但是由于我们配置文件中的seata-namespace-id为空,所以不用进行这一步

4. nacos中新增配置

  • nacos配置列表中新增配置,Data id 对应配置文件中的seataServer.properties,Group为DEFAULT_GROUP
    微服务高级篇【2】之Seata部署_第5张图片
    微服务高级篇【2】之Seata部署_第6张图片
  • 详细的配置内容:
    # 数据存储方式,db代表数据库
    store.mode=db
    store.db.datasource=druid
    store.db.dbType=mysql
    store.db.driverClassName=com.mysql.jdbc.Driver
    store.db.url=jdbc:mysql://127.0.0.1:3306/seata?useUnicode=true&rewriteBatchedStatements=true
    store.db.user=root
    store.db.password=xxxx 
    store.db.minConn=5
    store.db.maxConn=30
    store.db.globalTable=global_table
    store.db.branchTable=branch_table
    store.db.queryLimit=100
    store.db.lockTable=lock_table
    store.db.maxWait=5000
    # 事务、日志等配置
    server.recovery.committingRetryPeriod=1000
    server.recovery.asynCommittingRetryPeriod=1000
    server.recovery.rollbackingRetryPeriod=1000
    server.recovery.timeoutRetryPeriod=1000
    server.maxCommitRetryTimeout=-1
    server.maxRollbackRetryTimeout=-1
    server.rollbackRetryTimeoutUnlockEnable=false
    server.undo.logSaveDays=7
    server.undo.logDeletePeriod=86400000
    
    # 客户端与服务端传输方式
    transport.serialization=seata
    transport.compressor=none
    # 关闭metrics功能,提高性能
    metrics.enabled=false
    metrics.registryType=compact
    metrics.exporterList=prometheus
    metrics.exporterPrometheusPort=9898
    

5. 创建数据库表

  • 特别注意:tc服务在管理分布式事务时,需要记录事务相关数据到数据库中,需要提前创建好这些表。
  • 新建一个名为seata的数据库,以下代码:
    SET NAMES utf8mb4;
    SET FOREIGN_KEY_CHECKS = 0;
    
    -- ----------------------------
    -- 分支事务表
    -- ----------------------------
    DROP TABLE IF EXISTS `branch_table`;
    CREATE TABLE `branch_table`  (
      `branch_id` bigint(20) NOT NULL,
      `xid` varchar(128) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
      `transaction_id` bigint(20) NULL DEFAULT NULL,
      `resource_group_id` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
      `resource_id` varchar(256) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
      `branch_type` varchar(8) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
      `status` tinyint(4) NULL DEFAULT NULL,
      `client_id` varchar(64) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
      `application_data` varchar(2000) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
      `gmt_create` datetime(6) NULL DEFAULT NULL,
      `gmt_modified` datetime(6) NULL DEFAULT NULL,
      PRIMARY KEY (`branch_id`) USING BTREE,
      INDEX `idx_xid`(`xid`) USING BTREE
    ) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Compact;
    
    -- ----------------------------
    -- 全局事务表
    -- ----------------------------
    DROP TABLE IF EXISTS `global_table`;
    CREATE TABLE `global_table`  (
      `xid` varchar(128) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
      `transaction_id` bigint(20) NULL DEFAULT NULL,
      `status` tinyint(4) NOT NULL,
      `application_id` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
      `transaction_service_group` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
      `transaction_name` varchar(128) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
      `timeout` int(11) NULL DEFAULT NULL,
      `begin_time` bigint(20) NULL DEFAULT NULL,
      `application_data` varchar(2000) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
      `gmt_create` datetime NULL DEFAULT NULL,
      `gmt_modified` datetime NULL DEFAULT NULL,
      PRIMARY KEY (`xid`) USING BTREE,
      INDEX `idx_gmt_modified_status`(`gmt_modified`, `status`) USING BTREE,
      INDEX `idx_transaction_id`(`transaction_id`) USING BTREE
    ) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Compact;
    
    SET FOREIGN_KEY_CHECKS = 1;
    

6. 启动TC服务

  • 进入bin目录,运行其中的seata-server.bat即可,启动成功后,seata-server应该已经注册到nacos注册中心
  • 打开浏览器,访问nacos地址:http://localhost:8848,然后进入服务列表页面,可以看到seata-tc-server的信息。
    微服务高级篇【2】之Seata部署_第7张图片
    微服务高级篇【2】之Seata部署_第8张图片

你可能感兴趣的:(微服务学习,微服务,java,架构)