linux安装seata&Docker安装seata

1.wget https://github.com/seata/seata/releases/download/v1.4.2/seata-server-1.4.2.tar.gz
2.tar -zxf seata-server-1.4.2.tar.gz
3.mv seata /usr/local
4.修改file.conf registry.conf
5.初始化数据库脚本(从git下载)
6.启动
./bin/seata-server.sh &
jdk17会报错,在seata-server.sh文件中去掉CMS垃圾回收器相关配置 并加上–add-opens=java.base/java.lang=ALL-UNNAMED 然后再启动

服务器上启动后,客户端连不上可能是由于注册到nacos地址是本地地址,启动时加上-h:ip

./bin/seata-server.sh -h 121.4.63.94 &

Docker安装seata

docker pull seataio/seata-server:1.5.2
支持jdk17的新版本为【对比过,两个版本配置文件完全相同】
docker pull seataio/seata-server:1.6.1

上传配置至Nacos配置中心
通过dataId配置
1.从v1.4.2版本开始,已支持从一个Nacos dataId中获取所有配置信息,你只需要额外添加一个dataId配置项。

2.首先你需要在nacos新建配置,此处dataId为seataServer.properties,配置内容参考https://github.com/seata/seata/tree/develop/script/config-center 的config.txt并按需修改保存
config.txt内容如下:

#For details about configuration items, see https://seata.io/zh-cn/docs/user/configurations.html
#Transport configuration, for client and server
transport.type=TCP
transport.server=NIO
transport.heartbeat=true
transport.enableTmClientBatchSendRequest=false
transport.enableRmClientBatchSendRequest=true
transport.enableTcServerBatchSendResponse=false
transport.rpcRmRequestTimeout=30000
transport.rpcTmRequestTimeout=30000
transport.rpcTcRequestTimeout=30000
transport.threadFactory.bossThreadPrefix=NettyBoss
transport.threadFactory.workerThreadPrefix=NettyServerNIOWorker
transport.threadFactory.serverExecutorThreadPrefix=NettyServerBizHandler
transport.threadFactory.shareBossWorker=false
transport.threadFactory.clientSelectorThreadPrefix=NettyClientSelector
transport.threadFactory.clientSelectorThreadSize=1
transport.threadFactory.clientWorkerThreadPrefix=NettyClientWorkerThread
transport.threadFactory.bossThreadSize=1
transport.threadFactory.workerThreadSize=default
transport.shutdown.wait=3
transport.serialization=seata
transport.compressor=none

#Transaction routing rules configuration, only for the client
service.vgroupMapping.default_tx_group=default
#If you use a registry, you can ignore it
service.default.grouplist=127.0.0.1:8091
service.enableDegrade=false
service.disableGlobalTransaction=false

#Transaction rule configuration, only for the client
client.rm.asyncCommitBufferLimit=10000
client.rm.lock.retryInterval=10
client.rm.lock.retryTimes=30
client.rm.lock.retryPolicyBranchRollbackOnConflict=true
client.rm.reportRetryCount=5
client.rm.tableMetaCheckEnable=true
client.rm.tableMetaCheckerInterval=60000
client.rm.sqlParserType=druid
client.rm.reportSuccessEnable=false
client.rm.sagaBranchRegisterEnable=false
client.rm.sagaJsonParser=fastjson
client.rm.tccActionInterceptorOrder=-2147482648
client.tm.commitRetryCount=5
client.tm.rollbackRetryCount=5
client.tm.defaultGlobalTransactionTimeout=60000
client.tm.degradeCheck=false
client.tm.degradeCheckAllowTimes=10
client.tm.degradeCheckPeriod=2000
client.tm.interceptorOrder=-2147482648
client.undo.dataValidation=true
client.undo.logSerialization=jackson
client.undo.onlyCareUpdateColumns=true
server.undo.logSaveDays=7
server.undo.logDeletePeriod=86400000
client.undo.logTable=undo_log
client.undo.compress.enable=true
client.undo.compress.type=zip
client.undo.compress.threshold=64k
#For TCC transaction mode
tcc.fence.logTableName=tcc_fence_log
tcc.fence.cleanPeriod=1h

#Log rule configuration, for client and server
log.exceptionRate=100

#Transaction storage configuration, only for the server. The file, DB, and redis configuration values are optional.
store.mode=file
store.lock.mode=file
store.session.mode=file
#Used for password encryption
store.publicKey=

#If `store.mode,store.lock.mode,store.session.mode` are not equal to `file`, you can remove the configuration block.
store.file.dir=file_store/data
store.file.maxBranchSessionSize=16384
store.file.maxGlobalSessionSize=512
store.file.fileWriteBufferCacheSize=16384
store.file.flushDiskMode=async
store.file.sessionReloadReadSize=100

#These configurations are required if the `store mode` is `db`. If `store.mode,store.lock.mode,store.session.mode` are not equal to `db`, you can remove the configuration block.
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=username
store.db.password=password
store.db.minConn=5
store.db.maxConn=30
store.db.globalTable=global_table
store.db.branchTable=branch_table
store.db.distributedLockTable=distributed_lock
store.db.queryLimit=100
store.db.lockTable=lock_table
store.db.maxWait=5000

#These configurations are required if the `store mode` is `redis`. If `store.mode,store.lock.mode,store.session.mode` are not equal to `redis`, you can remove the configuration block.
store.redis.mode=single
store.redis.single.host=127.0.0.1
store.redis.single.port=6379
store.redis.sentinel.masterName=
store.redis.sentinel.sentinelHosts=
store.redis.maxConn=10
store.redis.minConn=1
store.redis.maxTotal=100
store.redis.database=0
store.redis.password=
store.redis.queryLimit=100

#Transaction rule configuration, only for the server
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.distributedLockExpireTime=10000
server.xaerNotaRetryTimeout=60000
server.session.branchAsyncQueueSize=5000
server.session.enableBranchAsyncRemove=false
server.enableParallelRequestHandle=false

#Metrics configuration, only for the server
metrics.enabled=false
metrics.registryType=compact
metrics.exporterList=prometheus
metrics.exporterPrometheusPort=9898

通过脚本上传配置到Nacos
参考https://github.com/seata/seata/tree/develop/script/config-center 的config.txt并修改,之后运行仓库中提供的nacos脚本,将信息提交到nacos控制台,如果有需要更改,可直接通过控制台更改.

eg: sh ${SEATAPATH}/script/config-center/nacos/nacos-config.sh -h localhost -p 8848 -g SEATA_GROUP -t 5a3c7d6c-f497-4d68-a71a-2e5e3340b3ca -u username -w password

我是手工建的,用这个脚本放不到dataId: seataServer.properties里

sh nacos-config.sh -h 121.4.63.94 -p 8848 -g SEATA_GROUP -t seata -u nacos -w nacos

3.在client参考如下配置进行修改,

seata:
  config:
    type: nacos
    nacos:
      server-addr: 127.0.0.1:8848
      group : "SEATA_GROUP"
      namespace: ""
      dataId: "seataServer.properties"
      username: "nacos"
      password: "nacos"
docker run -d --name seata-server -p 8091:8091 -p 7091:7091  -v /opt/services/seata/seata-config:/seata-server/seata-config -v /opt/services/seata/logs:/root/logs/seata -e SEATA_CONFIG_NAME=file:/seata-server/seata-config/application.yml seataio/seata-server:1.5.2

#如果你想将你的seata 服务部署到服务器上,可以在命令中执行seata 所在服务器的公网ip
#SEATA_IP 可选,指定seata-server启动的IP,该IP用于向注册中心注册时使用,如eureka等.

docker run -d --name seata-server -p 8091:8091 -p 7091:7091 -e SEATA_IP=公网ip -e TZ=Asia/Shanghai -v /opt/services/seata/resources/application.yml:/seata-server/resources/application.yml -v /opt/services/seata/logs:/root/logs/seata seataio/seata-server:1.5.2
Seata 是一个开源的分布式事务解决方案,可以在 Docker 环境中进行安装。下面是安装 Seata 的步骤: 1. 首先,确保你已经安装DockerDocker Compose。 2. 创建一个文件夹,用于存放 Seata 的配置文件和脚本。在该文件夹中创建一个名为 `docker-compose.yml` 的文件,并将以下内容复制到该文件中: ```yaml version: '3' services: seata-server: image: seataio/seata-server ports: - "8091:8091" environment: - SEATA_PORT=8091 volumes: - ./config:/seata-server/config ``` 3. 在同一文件夹中创建一个名为 `registry.conf` 的文件,并复制以下内容到该文件中: ```ini registry { type = "file" file { name = "file.conf" } } ``` 4. 在同一文件夹中创建一个名为 `file.conf` 的文件,并复制以下内容到该文件中: ```ini store { mode = "file" file { dir = "sessionStore" } } ``` 5. 创建一个名为 `sessionStore` 的文件夹,用于存储 Seata 的会话数据。 6. 打开终端或命令提示符,进入到包含以上文件的文件夹中。 7. 运行以下命令启动 Seata 容器: ``` docker-compose up -d ``` 8. 等待一段时间,直到容器启动完成。你可以使用以下命令查看容器的状态: ``` docker ps ``` 9. 如果一切顺利,你应该能够看到名为 `seata-server` 的容器正在运行。 至此,你已经成功地在 Docker 环境中安装Seata。你可以通过 `http://localhost:8091` 访问 Seata 控制台来管理和监控你的分布式事务。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值