項目位址: https://github.com/seata/seata
項目官網: https://seata.io/zh-cn/docs/overview/what-is-seata.html
重要bug提示:seata at模式 每個庫中的undo_log表的id一定删除掉,不然業務資料添加時傳回的id會擷取undo_log表中最新id設定到實體裡面,1.4.2版本已經廢棄id字段了
常見問題: https://seata.io/zh-cn/docs/overview/faq.html 問題10有說明
兩個版本方式:
1、拉取鏡像
docker pull seataio/seata-server:1.2.0
docker pull seataio/seata-server:1.3.0
docker pull seataio/seata-server:1.4.2
2、運作鏡像
docker run --name seata-server -p 8091:8091 -d seataio/seata-server:1.2.0
docker run --name seata1.3.0 -p 8091:8091 -d seataio/seata-server:1.3.0
docker run --name seata1.4.2 -p 8091:8091 -d seataio/seata-server:1.4.2
3、複制配置檔案到主機
docker cp seata-server:/seata-server /home/dockerdata/seata
docker cp seata1.3.0:/seata-server /home/dockerdata/seata1.3.0
docker cp seata1.4.2:/seata-server /home/dockerdata/seata1.4.2
4、停止服務
docker stop seata-server
docker stop seata1.3.0
docker stop seata1.4.2
5、删除服務
docker rm seata-server
docker rm seata1.3.0
docker rm seata1.4.2
6、重新運作服務,至此服務已經啟動完成,接下來就是在/home/dockerdata/seata/seata-server目錄中修改對應的配置(設定開機自啟和關鍵配置挂載到本地目錄友善修改配置)
docker run -d --restart always --name seata-server -p 8091:8091 -v /home/dockerdata/seata/seata-server:/seata-server -e SEATA_IP=172.168.1.35 -e SEATA_PORT=8091 seataio/seata-server:1.2.0
docker run -d --restart always --name seata1.3.0 -p 8091:8091 -v /home/dockerdata/seata1.3.0/seata-server:/seata-server -e SEATA_IP=172.168.1.35 -e SEATA_PORT=8091 seataio/seata-server:1.3.0
docker run -d --restart always --name seata1.4.2 -p 8091:8091 -v /home/dockerdata/seata1.4.2/seata-server:/seata-server -e SEATA_IP=172.168.1.35 -e SEATA_PORT=8091 seataio/seata-server:1.4.2
7、切換到seata配置目錄
cd /home/dockerdata/seata/seata-server/resources
cd /home/dockerdata/seata1.3.0/seata-server/resources
cd /home/dockerdata/seata1.4.2/seata-server/resources
8、修改registry.conf檔案,修為nacos啟用方式,綠色字型為修改的關鍵地方
registry {
# file 、nacos 、eureka、redis、zk、consul、etcd3、sofa
type = "nacos"
nacos {
application = "seata-server"
serverAddr = "172.168.1.35:8848"
namespace = "89f54c6f-3b21-46a4-bd1b-242ae159c12e"
cluster = "default"
username = ""
password = ""
}
eureka {
serviceUrl = "http://localhost:8761/eureka"
application = "default"
weight = "1"
}
redis {
serverAddr = "localhost:6379"
db = 0
password = ""
cluster = "default"
timeout = 0
}
zk {
cluster = "default"
serverAddr = "127.0.0.1:2181"
sessionTimeout = 6000
connectTimeout = 2000
username = ""
password = ""
}
consul {
cluster = "default"
serverAddr = "127.0.0.1:8500"
}
etcd3 {
cluster = "default"
serverAddr = "http://localhost:2379"
}
sofa {
serverAddr = "127.0.0.1:9603"
application = "default"
region = "DEFAULT_ZONE"
datacenter = "DefaultDataCenter"
cluster = "default"
group = "SEATA_GROUP"
addressWaitTime = "3000"
}
file {
name = "file.conf"
}
}
config {
# file、nacos 、apollo、zk、consul、etcd3
type = "file"
nacos {
serverAddr = "172.168.1.35:8848"
namespace = "89f54c6f-3b21-46a4-bd1b-242ae159c12e"
group = "DEFAULT_GROUP"
username = ""
password = ""
}
consul {
serverAddr = "127.0.0.1:8500"
}
apollo {
appId = "seata-server"
apolloMeta = "http://192.168.1.204:8801"
namespace = "application"
}
zk {
serverAddr = "127.0.0.1:2181"
sessionTimeout = 6000
connectTimeout = 2000
username = ""
password = ""
}
etcd3 {
serverAddr = "http://localhost:2379"
}
file {
name = "file.conf"
}
}
項目中的庫需要執行,sql檔案路徑:https://github.com/seata/seata/tree/develop/script/client
seata服務 需要sql https://github.com/seata/seata/tree/develop/script/server
不用的模式執行不同的腳本
具體的注意點檢視/home/dockerdata/seata/resources/README-zh.md
9、修改file.conf存儲方式為mysql
store {
## store mode: file、db
mode = "db"
## file store property
file {
## store location dir
dir = "sessionStore"
# branch session size , if exceeded first try compress lockkey, still exceeded throws exceptions
maxBranchSessionSize = 16384
# globe session size , if exceeded throws exceptions
maxGlobalSessionSize = 512
# file buffer size , if exceeded allocate new buffer
fileWriteBufferCacheSize = 16384
# when recover batch read size
sessionReloadReadSize = 100
# async, sync
flushDiskMode = async
}
## database store property
db {
## the implement of javax.sql.DataSource, such as DruidDataSource(druid)/BasicDataSource(dbcp) etc.
datasource = "druid"
## mysql/oracle/postgresql/h2/oceanbase etc.
dbType = "mysql"
driverClassName = "com.mysql.jdbc.Driver"
url = "jdbc:mysql://127.0.0.1:3306/seata?useUnicode=true&characterEncoding=utf8&autoReconnect=true&useSSL=false&serverTimezone=Asia/Shanghai"
user = "root"
password = "root"
minConn = 5
maxConn = 30
globalTable = "global_table"
branchTable = "branch_table"
lockTable = "lock_table"
queryLimit = 100
maxWait = 5000
}
}
10、重新開機服務
docker restart seata-server
docker logs seata-server #檢視啟動日志
11、可以登入nacos檢視服務清單,就會發現seata-server已經注冊上來了