当前位置:   article > 正文

SpringBoot+ Dubbo + Mybatis + Nacos +Seata整合来实现Dubbo分布式事务_dubbo分布式事务解决方案

dubbo分布式事务解决方案

1.简介

本文主要介绍SpringBoot2.1.5 + Dubbo 2.7.3 + Mybatis 3.4.2 + Nacos 1.1.3 +Seata 0.8.0整合来实现Dubbo分布式事务管理,使用Nacos 作为 Dubbo和Seata的注册中心和配置中心,使用 MySQL 数据库和 MyBatis来操作数据。

如果你还对SpringBootDubboNacosSeataMybatis 不是很了解的话,这里我为大家整理个它们的官网网站,如下

  • SpringBoot:https://spring.io/projects/spring-boot

  • Dubbo:http://dubbo.apache.org/en-us/

  • Nacos:https://nacos.io/zh-cn/docs/quick-start.html

  • Seata:https://github.com/seata/seata/wiki/Home_Chinese

  • MyBatis:http://www.mybatis.org/mybatis-3/zh/index.html

在这里我们就不一个一个介绍它们是怎么使用和原理,详细请学习官方文档,在这里我将开始对它们进行整合,完成一个简单的案例,来让大家了解Seata来实现Dubbo分布式事务管理的基本流程。

2.环境准备

2.1 下载nacos并安装启动

nacos下载:https://github.com/alibaba/nacos/releases/tag/1.1.3

Nacos 快速入门:https://nacos.io/en-us/docs/quick-start.html

  1. sh startup.sh -m standalone
  2. 1

在浏览器打开Nacos web 控制台:http://192.168.10.200:8848/nacos/index.html

输入nacos的账号和密码 分别为nacos:nacos

这是时候naocs 就正常启动了。

2.2 下载seata0.8.0 并安装启动

2.2.1 在 Seata Release 下载最新版的 Seata Server 并解压得到如下目录:
  1. .
  2. ├──bin
  3. ├──conf
  4. ├──file_store
  5. └──lib
  6. 12345
2.2.2 修改 conf/registry.conf 配置,

目前seata支持如下的file、nacos 、apollo、zk、consul的注册中心和配置中心。这里我们以nacos 为例。将 type 改为 nacos

  1. registry {
  2.   # file nacos
  3.   type = "nacos"
  4.   nacos {
  5.     serverAddr = "192.168.10.200:8848"
  6.     namespace = "public"
  7.     cluster = "default"
  8.   }
  9.   file {
  10.     name = "file.conf"
  11.   }
  12. }
  13. config {
  14.   # file、nacos 、apollo、zk、consul
  15.   type = "nacos"
  16.   nacos {
  17.     serverAddr = "192.168.10.200:8848"
  18.     namespace = "public"
  19.     cluster = "default"
  20.   }
  21.   file {
  22.     name = "file.conf"
  23.   }
  24. }
  25. 1234567891011121314151617181920212223242526272829
  • serverAddr = “192.168.10.200:8848” :nacos 的地址

  • namespace = “public” :nacos的命名空间默认为public

  • cluster = “default” :集群设置未默认 default

注意:seata0.9.0之后,配置如下, 其中namespace = ""

  1. registry {
  2.   # file nacos
  3.   type = "nacos"
  4.   nacos {
  5.     serverAddr = "192.168.10.200:8848"
  6.     namespace = ""
  7.     cluster = "default"
  8.   }
  9.   file {
  10.     name = "file.conf"
  11.   }
  12. }
  13. config {
  14.   # file、nacos 、apollo、zk、consul
  15.   type = "nacos"
  16.   nacos {
  17.     serverAddr = "192.168.10.200:8848"
  18.     namespace = ""
  19.   }
  20.   file {
  21.     name = "file.conf"
  22.   }
  23. }
  24. 123456789101112131415161718192021222324252627
2.2.3 修改 conf/nacos-config.txt配置

注意:如果你的seata是1.1之后的版本请按照如下导入方式操作

  1. 下载https://github.com/seata/seata/blob/develop/script/config-center/目录下的config.txt文件放入到seata-server目录下的conf中,可更改文件名为nacos-config.txt

  2. 下载https://github.com/seata/seata/tree/develop/script/config-center/nacos/目录下的nacos-config.py文件(window可用python命令执行,linux也可执行,前提先有安装python)或者nacos-config.sh文件(window下可放在git命令行执行,linux可执行文件)

  1. transport.type=TCP
  2. transport.server=NIO
  3. transport.heartbeat=true
  4. transport.thread-factory.boss-thread-prefix=NettyBoss
  5. transport.thread-factory.worker-thread-prefix=NettyServerNIOWorker
  6. transport.thread-factory.server-executor-thread-prefix=NettyServerBizHandler
  7. transport.thread-factory.share-boss-worker=false
  8. transport.thread-factory.client-selector-thread-prefix=NettyClientSelector
  9. transport.thread-factory.client-selector-thread-size=1
  10. transport.thread-factory.client-worker-thread-prefix=NettyClientWorkerThread
  11. transport.thread-factory.boss-thread-size=1
  12. transport.thread-factory.worker-thread-size=8
  13. transport.shutdown.wait=3
  14. service.vgroup_mapping.order-service-seata-service-group=default
  15. service.vgroup_mapping.account-service-seata-service-group=default
  16. service.vgroup_mapping.storage-service-seata-service-group=default
  17. service.vgroup_mapping.business-service-seata-service-group=default
  18. service.enableDegrade=false
  19. service.disable=false
  20. service.max.commit.retry.timeout=-1
  21. service.max.rollback.retry.timeout=-1
  22. client.async.commit.buffer.limit=10000
  23. client.lock.retry.internal=10
  24. client.lock.retry.times=30
  25. store.mode=db
  26. store.file.dir=file_store/data
  27. store.file.max-branch-session-size=16384
  28. store.file.max-global-session-size=512
  29. store.file.file-write-buffer-cache-size=16384
  30. store.file.flush-disk-mode=async
  31. store.file.session.reload.read_size=100
  32. store.db.driver-class-name=com.mysql.jdbc.Driver
  33. store.db.datasource=dbcp
  34. store.db.db-type=mysql
  35. store.db.url=jdbc:mysql://192.168.10.200:3306/seata?useUnicode=true
  36. store.db.user=lidong
  37. store.db.password=cwj887766@@
  38. store.db.min-conn=1
  39. store.db.max-conn=3
  40. store.db.global.table=global_table
  41. store.db.branch.table=branch_table
  42. store.db.query-limit=100
  43. store.db.lock-table=lock_table
  44. recovery.committing-retry-period=1000
  45. recovery.asyn-committing-retry-period=1000
  46. recovery.rollbacking-retry-period=1000
  47. recovery.timeout-retry-period=1000
  48. transaction.undo.data.validation=true
  49. transaction.undo.log.serialization=jackson
  50. transaction.undo.log.save.days=7
  51. transaction.undo.log.delete.period=86400000
  52. transaction.undo.log.table=undo_log
  53. transport.serialization=seata
  54. transport.compressor=none
  55. metrics.enabled=false
  56. metrics.registry-type=compact
  57. metrics.exporter-list=prometheus
  58. metrics.exporter-prometheus-port=9898
  59. service.default.grouplist=127.0.0.1:8091
  60. 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859

这里主要修改了如下几项:

  • store.mode :存储模式 默认file 这里我修改为db 模式 ,并且需要三个表global_tablebranch_tablelock_table

  • store.db.driver-class-name:默认没有,会报错。添加了 com.mysql.jdbc.Driver

  • store.db.datasource=dbcp :数据源 dbcp

  • store.db.db-type=mysql : 存储数据库的类型为mysql

  • store.db.url=jdbc:mysql://192.168.10.200:3306/seata?useUnicode=true : 修改为自己的数据库urlport数据库名称

  • store.db.user=lidong :数据库的账号

  • store.db.password=cwj887766@@ :数据库的密码

  • service.vgroup_mapping.order-service-seata-service-group=default

  • service.vgroup_mapping.account-service-seata-service-group=default

  • service.vgroup_mapping.storage-service-seata-service-group=default

  • service.vgroup_mapping.business-service-seata-service-group=default

也可以在 Nacos 配置页面添加,data-id 为 service.vgroup_mapping.${YOUR_SERVICE_NAME}-seata-service-group, group 为 SEATA_GROUP, 如果不添加该配置,启动后会提示no available server to connect to services-server

注意: 配置文件末尾有空行,需要删除,否则会提示失败,尽管实际上是成功的

db模式下的所需的三个表的数据库脚本位于seata\conf\db_store.sql

global_table的表结构

  1. CREATE TABLE `global_table` (
  2.   `xid` varchar(128NOT NULL,
  3.   `transaction_id` bigint(20DEFAULT NULL,
  4.   `status` tinyint(4NOT NULL,
  5.   `application_id` varchar(64DEFAULT NULL,
  6.   `transaction_service_group` varchar(64DEFAULT NULL,
  7.   `transaction_name` varchar(64DEFAULT NULL,
  8.   `timeout` int(11DEFAULT NULL,
  9.   `begin_time` bigint(20DEFAULT NULL,
  10.   `application_data` varchar(2000DEFAULT NULL,
  11.   `gmt_create` datetime DEFAULT NULL,
  12.   `gmt_modified` datetime DEFAULT NULL,
  13.   PRIMARY KEY (`xid`),
  14.   KEY `idx_gmt_modified_status` (`gmt_modified`,`status`),
  15.   KEY `idx_transaction_id` (`transaction_id`)
  16. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
  17. 1234567891011121314151617

branch_table的表结构

  1. CREATE TABLE `branch_table` (
  2.   `branch_id` bigint(20NOT NULL,
  3.   `xid` varchar(128NOT NULL,
  4.   `transaction_id` bigint(20DEFAULT NULL,
  5.   `resource_group_id` varchar(32DEFAULT NULL,
  6.   `resource_id` varchar(256DEFAULT NULL,
  7.   `lock_key` varchar(128DEFAULT NULL,
  8.   `branch_type` varchar(8DEFAULT NULL,
  9.   `status` tinyint(4DEFAULT NULL,
  10.   `client_id` varchar(64DEFAULT NULL,
  11.   `application_data` varchar(2000DEFAULT NULL,
  12.   `gmt_create` datetime DEFAULT NULL,
  13.   `gmt_modified` datetime DEFAULT NULL,
  14.   PRIMARY KEY (`branch_id`),
  15.   KEY `idx_xid` (`xid`)
  16. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
  17. 123456789101112131415161718

lock_table的表结构

  1. create table `lock_table` (
  2.   `row_key` varchar(128not null,
  3.   `xid` varchar(96),
  4.   `transaction_id` long ,
  5.   `branch_id` long,
  6.   `resource_id` varchar(256) ,
  7.   `table_name` varchar(32) ,
  8.   `pk` varchar(32) ,
  9.   `gmt_create` datetime ,
  10.   `gmt_modified` datetime,
  11.   primary key(`row_key`)
  12. );
  13. 123456789101112
2.2.4 将 Seata 配置添加到 Nacos 中

使用命令如下

  1. cd conf
  2. sh nacos-config.sh localhost
  3. 12

成功后会提示

  1. init nacos config finished, please start seata-server
  2. 1

在 Nacos 管理页面应该可以看到有 59 个 Group 为SEATA_GROUP的配置

2.2.5 启动 Seata Server
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Monodyee/article/detail/165658
推荐阅读
相关标签
  

闽ICP备14008679号