微服务之分布式事务服务端搭建(seata 1.0以下版本)

简介: 微服务之分布式事务服务端搭建(seata 1.0以下版本)

今天同事咨询我什么事分布式事务?怎么用分布式事务?有没有什么好的中间件来解决分布式事务?
所谓分布式事务,事务的参与者、支持事务的服务器、资源服务器以及事务管理器分别位于不同的分布式系统的不同节点之上。
这就是问题所在不同的服务之间怎么去控制事务呢?今天我们所要了解的seata便能很好的解决这一难题!接下来我们进入今天的学习干活。

1、下载地址:seata.io/zh-cn/blog/…

(我这里选择的是1.0以下版本。0.9.0版本的,1.0以上的配置和这里不一样。后面会发文章单独讲解1.0以上版本的配置)

2、下载后在E:\tools\seata\seata-server-0.9.0\conf

文件内备份file.conf及registry.conf两个文件,以防改错文件,用以快速恢复。这里主要修改file.conf文件中的事务组名称、事务日志存储模式为db、数据库链接信息这三个
image.png
image.png
image.png

3、创建seata库,然后在目录中将建表文件执行(E:\tools\seata\seata-server-0.9.0\conf\db_store.sql)

表global_table,将表中transaction_service_group字段原有32的长度更改作为256长度
这样可避免一下字段长度超长问题

4、修改registry.conf文件,调整注册中心为nacos,指向我们的nacos注册中心

image.png

5、启动nacos(这个必须先与seata-server先启动,不然找不到可用服务)

6、启动seata-server服务,查看nacos控制台出现如下图所示,则说明seata-server启动成功

命令:./seata-server.sh -h ip地址 -p 8091 &
image.png

7、在各自业务库中新建日志回滚表(E:\tools\seata\seata-server-0.9.0\conf\db_undo_log.sql)

如果没有此文件,可按下方sql创建
drop table undo_log; CREATE TABLE undo_log( idbigint(20) NOT NULL AUTO_INCREMENT, branch_idbigint(20) NOT NULL, xidvarchar(100) NOT NULL, contextvarchar(128) NOT NULL, rollback_infolongblob NOT NULL, log_statusint(11) NOT NULL, log_createddatetime NOT NULL, log_modifieddatetime NOT NULL, ext varchar(100) DEFAULT NULL, PRIMARY KEY (id), UNIQUE KEY ux_undo_log (xid,branch_id) ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
服务端的搭建到此就完成了,记下来我们会更新业务端代码!

目录
相关文章
|
6月前
|
安全 应用服务中间件 API
微服务分布式系统架构之zookeeper与dubbo-2
微服务分布式系统架构之zookeeper与dubbo-2
|
6月前
|
负载均衡 Java 应用服务中间件
微服务分布式系统架构之zookeeper与dubbor-1
微服务分布式系统架构之zookeeper与dubbor-1
|
2月前
|
Java 关系型数据库 数据库
微服务SpringCloud分布式事务之Seata
SpringCloud+SpringCloudAlibaba的Seata实现分布式事务,步骤超详细,附带视频教程
101 1
|
5月前
|
前端开发 Java API
Apache Seata(incubating) 首个版本重磅发布!
2.1.0 是 Seata 进入 Apache 基金会的第一个 Release Version。此次发布将 io.seata 包名更改为 org.apache.seata。除了按原有的 Roadmap 技术演进外,2.1.0 进行了大量兼容性工作,实现了 API、数据和协议的兼容。用户无需修改原有的 API 和配置,即可实现到 Apache 版本的平滑升级。
154 20
Apache Seata(incubating) 首个版本重磅发布!
|
3月前
|
消息中间件 SQL 中间件
大厂都在用的分布式事务方案,Seata+RocketMQ带你打破10万QPS瓶颈
分布式事务涉及跨多个数据库或服务的操作,确保数据一致性。本地事务通过数据库直接支持ACID特性,而分布式事务则需解决跨服务协调难、高并发压力及性能与一致性权衡等问题。常见的解决方案包括两阶段提交(2PC)、Seata提供的AT和TCC模式、以及基于消息队列的最终一致性方案。这些方法各有优劣,适用于不同业务场景,选择合适的方案需综合考虑业务需求、系统规模和技术团队能力。
458 7
|
3月前
|
存储 运维 数据可视化
如何为微服务实现分布式日志记录
如何为微服务实现分布式日志记录
156 1
|
5月前
|
消息中间件 存储 负载均衡
微服务与分布式系统设计看这篇就够了!
【10月更文挑战第12天】 在现代软件架构中,微服务和分布式系统设计已经成为构建可扩展、灵活和可靠应用程序的主流方法。本文将深入探讨微服务架构的核心概念、设计原则和挑战,并提供一些关于如何在分布式系统中实现微服务的实用指导。
200 2
|
5月前
|
人工智能 文字识别 Java
SpringCloud+Python 混合微服务,如何打造AI分布式业务应用的技术底层?
尼恩,一位拥有20年架构经验的老架构师,通过其深厚的架构功力,成功指导了一位9年经验的网易工程师转型为大模型架构师,薪资逆涨50%,年薪近80W。尼恩的指导不仅帮助这位工程师在一年内成为大模型架构师,还让他管理起了10人团队,产品成功应用于多家大中型企业。尼恩因此决定编写《LLM大模型学习圣经》系列,帮助更多人掌握大模型架构,实现职业跃迁。该系列包括《从0到1吃透Transformer技术底座》、《从0到1精通RAG架构》等,旨在系统化、体系化地讲解大模型技术,助力读者实现“offer直提”。此外,尼恩还分享了多个技术圣经,如《NIO圣经》、《Docker圣经》等,帮助读者深入理解核心技术。
SpringCloud+Python 混合微服务,如何打造AI分布式业务应用的技术底层?
|
6月前
|
SQL NoSQL 数据库
SpringCloud基础6——分布式事务,Seata
分布式事务、ACID原则、CAP定理、Seata、Seata的四种分布式方案:XA、AT、TCC、SAGA模式
SpringCloud基础6——分布式事务,Seata
|
7月前
|
Java 数据库连接 微服务
揭秘微服务架构下的数据魔方:Hibernate如何玩转分布式持久化,实现秒级响应的秘密武器?
【8月更文挑战第31天】微服务架构通过将系统拆分成独立服务,提升了可维护性和扩展性,但也带来了数据一致性和事务管理等挑战。Hibernate 作为强大的 ORM 工具,在微服务中发挥关键作用,通过二级缓存和分布式事务支持,简化了对象关系映射,并提供了有效的持久化策略。其二级缓存机制减少数据库访问,提升性能;支持 JTA 保证跨服务事务一致性;乐观锁机制解决并发数据冲突。合理配置 Hibernate 可助力构建高效稳定的分布式系统。
98 0