docker compose部署单机seata2.0

352 阅读4分钟

前言:本文档基于mysql+nacos部署seata,操作前需要提前启动nacos与mysql服务

seata官方部署文档

为了获取seata server 1.5.0的配置文件,我们需要先启动一个seata server 1.5.0的服务,然后再从启动的容器实例中把默认的配置文件复制出来,再进行修改。

docker-compose.yaml

services:  
seata-server:  
image: seataio/seata-server:${latest-release-version}  
ports:  
- "7091:7091"  
- "8091:8091"

接下来通过docker cp命令把容器中/seata-server/resources位置的资源文件拷贝到宿主机指定位置(/srv/seata/resources)。 在宿主机指定位置我们就可以看到对应的application.yml配置文件,相关的配置只需要修改这个文件即可。

一、docker compose文件

  1. vi seata.yml加入以下内容
services:  
  seata-server:  
    image: seataio/seata-server:2.0.0  
    ports:  
      - "7091:7091"  
      - "8091:8091"  
    restart: always  
    container_name: seata  
    environment:  
      - STORE_MODE=db  
      # 以SEATA_IP作为host注册seata server  
      - SEATA_IP=192.168.31.167  
      - SEATA_PORT=8091  
    volumes:  
      - "/usr/share/zoneinfo/Asia/Shanghai:/etc/localtime"        #设置系统时区  
      - "/usr/share/zoneinfo/Asia/Shanghai:/etc/timezone"  #设置时区  
      - "/srv/seata/resources:/seata-server/resources"  
      - "/srv/seata/logs:/root/logs/seata"  
    networks:  
      - seata-n    
    logging:  
      driver: "json-file"  
      options:  
        max-size: "20m"  
        max-file: "3"   
    deploy:  
      resources:  
        limits:  
          memory: 1g  
          cpus: "0.5"  
  
networks:  
  seata-n:  
    driver: bridge

二、applaction.yml配置

  1. vi /srv/seata/resources/applaction.yml修改以下内容
server:
  port: 7091
  address: 0.0.0.0  # 监听所有网络接口

seata:
  config:
    # support: nacos, consul, apollo, zk, etcd3
    type: nacos
    nacos:
      server-addr: 192.168.31.167:8848
      namespace: 23db8e8d-c823-4bb6-97d1-0cff4959b37b
      group: SEATA_GROUP
      username: nacos
      password: 123456
      data-id: seataServer.properties

  registry:
    # support: nacos, eureka, redis, zk, consul, etcd3, sofa
    type: nacos
    nacos:
      application: seata-server
      server-addr: 192.168.31.167:8848
      group: SEATA_GROUP
      namespace: 23db8e8d-c823-4bb6-97d1-0cff4959b37b
      # tc集群名称
      cluster: default
      username: nacos
      password: nacos

  1. 给对应文件权限 chmod -R 766 /srv/seata/

三、准备nacos配置中心配置(修改数据库信息)

  1. 需要在nacos新建配置,此处dataId为seataServer.properties
store.mode=db  
#-----db-----  
store.db.datasource=druid  
store.db.dbType=mysql  
# 需要根据mysql的版本调整driverClassName  
# mysql8及以上版本对应的driver:com.mysql.cj.jdbc.Driver  
# mysql8以下版本的driver:com.mysql.jdbc.Driver  
store.db.driverClassName=com.mysql.cj.jdbc.Driver  
store.db.url=jdbc:mysql://192.168.31.167:3306/seata-server?useUnicode=true&characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useSSL=false  
store.db.user= root  
store.db.password=123456  
# 数据库初始连接数  
store.db.minConn=1  
# 数据库最大连接数  
store.db.maxConn=20  
# 获取连接时最大等待时间 默认5000,单位毫秒  
store.db.maxWait=5000  
# 全局事务表名 默认global_table  
store.db.globalTable=global_table  
# 分支事务表名 默认branch_table  
store.db.branchTable=branch_table  
# 全局锁表名 默认lock_table  
store.db.lockTable=lock_table  
# 查询全局事务一次的最大条数 默认100  
store.db.queryLimit=100  
  
# undo保留天数 默认7天,log_status=1(附录3)和未正常清理的undo  
server.undo.logSaveDays=7  
# undo清理线程间隔时间 默认86400000,单位毫秒  
server.undo.logDeletePeriod=86400000  
# 二阶段提交重试超时时长 单位ms,s,m,h,d,对应毫秒,秒,分,小时,天,默认毫秒。默认值-1表示无限重试  
# 公式: timeout>=now-globalTransactionBeginTime,true表示超时则不再重试  
# 注: 达到超时时间后将不会做任何重试,有数据不一致风险,除非业务自行可校准数据,否者慎用  
server.maxCommitRetryTimeout=-1  
# 二阶段回滚重试超时时长  
server.maxRollbackRetryTimeout=-1  
# 二阶段提交未完成状态全局事务重试提交线程间隔时间 默认1000,单位毫秒  
server.recovery.committingRetryPeriod=1000  
# 二阶段异步提交状态重试提交线程间隔时间 默认1000,单位毫秒  
server.recovery.asynCommittingRetryPeriod=1000  
# 二阶段回滚状态重试回滚线程间隔时间 默认1000,单位毫秒  
server.recovery.rollbackingRetryPeriod=1000  
# 超时状态检测重试线程间隔时间 默认1000,单位毫秒,检测出超时将全局事务置入回滚会话管理器  
server.recovery.timeoutRetryPeriod=1000

image.png

四、初始化mysql数据库

建表脚本

-- -------------------------------- 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`),
    KEY `idx_xid` (`xid`)
) 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 ('AsyncCommitting', ' ', 0);
INSERT INTO `distributed_lock` (lock_key, lock_value, expire) VALUES ('RetryCommitting', ' ', 0);
INSERT INTO `distributed_lock` (lock_key, lock_value, expire) VALUES ('RetryRollbacking', ' ', 0);
INSERT INTO `distributed_lock` (lock_key, lock_value, expire) VALUES ('TxTimeoutCheck', ' ', 0);

启动容器 docker compose -f ./seata.yml up -d

至此单机的seata部署完毕。