docker部署seata0.9.0版本

一、简单构建镜像

1.创建目录,用于存放安装包、Dockerfile等文件

mkdir -p  /home/myseata/

2.在此目录下创建Dockerfile文件

vim Dockerfile

dockerfile文件内容如下:

# 使用基础镜像
FROM openjdk:8-jre-alpine

# 设置环境变量
ENV SEATA_VERSION=0.9.0

# 创建工作目录
WORKDIR /seata

# 复制seata发布包到镜像中
COPY seata-server-${SEATA_VERSION}.tar.gz /seata

# 解压发布包
RUN tar -xvf seata-server-${SEATA_VERSION}.tar.gz && \
    rm seata-server-${SEATA_VERSION}.tar.gz

# 设置seata-server的启动命令
CMD ["sh", "/seata/seata/bin/seata-server.sh"]

3.将seata安装包复制到和dockefile文件同级目录下

如图:

在这里插入图片描述

4.制作镜像

docker build -t seata:0.9.0 . 

5.简单启动

docker run -d -p 8091:8091 --name seata seata:0.9.0

在这里插入图片描述

二、补充:实现以nacos作为注册中心,db模式存储

2.1 任意目录下创建2个文件 registry.conf、file.conf 主要用于挂载

我这儿文件存放位置为 /home/myseata
在这里插入图片描述

具体文件内容如下:
registery.conf:( 目的在于注册文件指定为ncaos模式,配置文件指定file)

registry {
  # file 、nacos 、eureka、redis、zk、consul、etcd3、sofa
  type = "nacos"

  nacos {
    serverAddr = "你的ip:8848"
    namespace = ""
    cluster = "default"
  }
 
  file {
    name = "file.conf"
  }
}

#配置方式选择 file 文件
config {
  # file、nacos 、apollo、zk、consul、etcd3
  type = "file"

  nacos {
    serverAddr = "localhost"
    namespace = "" 
  }
  consul {
    serverAddr = "127.0.0.1:8500"
  }
  apollo {
    app.id = "seata-server"
    apollo.meta = "http://192.168.1.204:8801"
  }
  zk {
    serverAddr = "127.0.0.1:2181"
    session.timeout = 6000
    connect.timeout = 2000
  }
  etcd3 {
    serverAddr = "http://localhost:2379"
  }
  file {
    name = "file.conf"
  }
}

file.conf

transport {
  # tcp udt unix-domain-socket
  type = "TCP"
  #NIO NATIVE
  server = "NIO"
  #enable heartbeat
  heartbeat = true
  #thread factory for netty
  thread-factory {
    boss-thread-prefix = "NettyBoss"
    worker-thread-prefix = "NettyServerNIOWorker"
    server-executor-thread-prefix = "NettyServerBizHandler"
    share-boss-worker = false
    client-selector-thread-prefix = "NettyClientSelector"
    client-selector-thread-size = 1
    client-worker-thread-prefix = "NettyClientWorkerThread"
    # netty boss thread size,will not be used for UDT
    boss-thread-size = 1
    #auto default pin or 8
    worker-thread-size = 8
  }
  shutdown {
    # when destroy server, wait seconds
    wait = 3
  }
  serialization = "seata"
  compressor = "none"
}
service {
  #vgroup->rgroup
  #改分组 需与项目yml文件里一致
  vgroup_mapping.my_test_tx_group = "default"  
  #only support single node
  #改ip
  default.grouplist = "你的ip:8091"   
  #degrade current not support
  enableDegrade = false
  #disable
  disable = false
  #unit ms,s,m,h,d represents milliseconds, seconds, minutes, hours, days, default permanent
  max.commit.retry.timeout = "-1"
  max.rollback.retry.timeout = "-1"
}

client {
  async.commit.buffer.limit = 10000
  lock {
    retry.internal = 10
    retry.times = 30
  }
  report.retry.count = 5
  tm.commit.retry.count = 1
  tm.rollback.retry.count = 1
}

## transaction log store
store {
  ## store mode: file、db
  mode = "db"

  ## file store
  file {
    dir = "sessionStore"

    # branch session size , if exceeded first try compress lockkey, still exceeded throws exceptions
    max-branch-session-size = 16384
    # globe session size , if exceeded throws exceptions
    max-global-session-size = 512
    # file buffer size , if exceeded allocate new buffer
    file-write-buffer-cache-size = 16384
    # when recover batch read size
    session.reload.read_size = 100
    # async, sync
    flush-disk-mode = async
  }

  ## database store
  ##改数据库有关配置
  db {
    ## the implement of javax.sql.DataSource, such as DruidDataSource(druid)/BasicDataSource(dbcp) etc.
    datasource = "dbcp"
    ## mysql/oracle/h2/oceanbase etc.
    db-type = "mysql"
    driver-class-name = "com.mysql.cj.jdbc.Driver" 
    url = "jdbc:mysql://你的ip:3306/seata_server?useSSL=false&&serverTimezone=GMT%2B8&useInformationSchema=true&useLocalSessionState=true"
    user = "账号"
    password = "密码"
    min-conn = 1
    max-conn = 3
    global.table = "global_table"
    branch.table = "branch_table"
    lock-table = "lock_table"
    query-limit = 100
  }
}
lock {
  ## the lock store mode: local、remote
  mode = "remote"

  local {
    ## store locks in user's database
  }

  remote {
    ## store locks in the seata's server
  }
}
recovery {
  #schedule committing retry period in milliseconds
  committing-retry-period = 1000
  #schedule asyn committing retry period in milliseconds
  asyn-committing-retry-period = 1000
  #schedule rollbacking retry period in milliseconds
  rollbacking-retry-period = 1000
  #schedule timeout retry period in milliseconds
  timeout-retry-period = 1000
}

transaction {
  undo.data.validation = true
  undo.log.serialization = "jackson"
  undo.log.save.days = 7
  #schedule delete expired undo_log in milliseconds
  undo.log.delete.period = 86400000
  undo.log.table = "undo_log"
}

## metrics settings
metrics {
  enabled = false
  registry-type = "compact"
  # multi exporters use comma divided
  exporter-list = "prometheus"
  exporter-prometheus-port = 9898
}

support {
  ## spring
  spring {
    # auto proxy the DataSource bean
    datasource.autoproxy = false
  }
}

2.2 启动

docker run --restart=always -d -p 8091:8091 -v /home/myseata/registry.conf/:/seata/seata/conf/registry.conf  -v /home/myseata/file.conf/:/seata/seata/conf/file.conf  -v /home/myseata/lib:/seata/seata/lib --name seata seata:0.9.0

2.3 效果图

在这里插入图片描述

2.4 注意点

1、注册文件 register目的就是指定注册方式,这里我选择了 nacos ,file 文件是为了指定如何存储,其中需要改动为 ip、数据库连接信息、项目里面对应的分组名称
2、在部署时可能会遇到seat对mysql兼容性问题,在lib文件里面 连接驱动 为5,而我连接为8 导致匹配不上,就需要下载8jar包提替换掉 然后数据卷挂载让容器也更新就行了 详细操作可参考:https://blog.csdn.net/qq_42915936/article/details/105206771

  • 12
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值