0

0

跨多个服务的事务操作是一种疯狂的方法

霞舞

霞舞

发布时间:2024-11-11 09:34:04

|

916人浏览过

|

来源于dev.to

转载

跨多个服务的事务操作是一种疯狂的方法

团队在微服务环境中必须处理的众多复杂问题之一就是事务。跨越多个微服务的事务。与单体应用程序不同,单体应用程序的事务通常使用单个数据库和 @transactional
进行管理 注解,在微服务中,每个服务往往都有自己的数据库,使得分布式事务变得更加复杂。这是有关如何在 spring boot 中有效处理这些分布式事务的指南。

首先,让我们先就什么是交易达成一致。

事务是计算或数据库环境中的一个工作单元,被视为单个不可分割的操作。它代表一系列必须一起成功或一起失败的操作或步骤,即使在发生意外事件(例如断电或网络故障)时也能确保数据的一致性和完整性。

在数据库上下文中,事务可能涉及多个查询,例如创建、更新或删除记录。交易通常遵循四个基本属性,称为 acid 属性:

a. 原子性 - 事务中的所有操作都被视为单个单元。要么所有操作成功,要么全部失败。

b. 一致性 - 事务将系统从一种有效状态转移到另一种有效状态,从而保持数据有效性。

c. 隔离 - 事务是隔离执行的,这意味着中间状态对其他事务不可见。

d. 持久性 - 事务一旦提交,其更改就是永久性的,并且在系统崩溃时也能幸存。


一个短篇故事

在一个繁忙的电子商务应用程序中,想象一下客户 alice 订购了一台新笔记本电脑、一个配件和快递。以下是她的订单如何在由 ordersagaorchestrator 管理的系统中流动的幕后故事。

在一个繁忙的电子商务应用程序中,想象一下客户 alice 订购了一台新笔记本电脑、一个配件和快递。以下是她的订单如何在由 ordersagaorchestrator 管理的系统中流动的幕后故事。

alice 输入付款和送货信息后点击“立即订购”。此操作启动了一个称为传奇的流程,这是一系列精心策划的交易,以确保她的订单从头到尾得到正确处理。

第 1 步:付款处理
saga 编排器首先检查 paymentservice,发起调用以从 alice 的帐户中扣除所需的金额。调用 paymentservice.processpayment() 方法,授权 alice 付款。

第2步:库存预订
一旦付款成功,协调器就会转移到 inventoryservice,在那里为 alice 保留特定的笔记本电脑型号和配件。此预订步骤至关重要,以便在订单仍在处理期间,库存不会售完或交给其他客户。

第 3 步:发货启动
成功预订库存后,saga 协调器将联系 shippingservice。在这里,shippingservice.initiateshipping() 启动物流,确保物品包装好并准备好运送到 alice 的地址。

处理失败:补偿逻辑

但是在分布式环境中,任何一步都可能出错。如果由于物流错误导致发货启动失败,或者由于库存差异而实际上无法履行库存怎么办?协调器已准备好补偿策略。

如果抛出异常,协调器将启动补偿事务以回滚整个过程,因此 alice 不会为她不会收到的物品付费:

3.1。取消发货 - 协调器调用shippingservice.cancelshipping(),停止发货。

3.2。释放库存 - 然后触发 inventoryservice.releaseinventory(),释放 alice 的保留物品,以便其他客户可以购买它们。

3.3。退款 - 最后,它调用 paymentservice.refund() 来退还 alice 的付款,确保她不会为订单付费。

最后,这个精心策划的传奇确保了 alice 的体验流畅且一致,如果出现任何问题,都会以维护系统完整性的方式解决。这就是微服务中分布式事务和补偿逻辑的魔力。


现在我们知道了什么是事务并了解了事务可能有用的现实场景,让我们深入研究如何在分布式环境中实现此功能。

团队可以使用一些关键方法来解决这个问题

1。 saga 模式: saga 模式是微服务架构中处理分布式事务最广泛使用的模式之一。传奇是每个服务独立执行的本地事务序列。 saga 中的每一步都会通过一个操作来补偿,如果 saga 失败,该操作会撤消该步骤。

OmniAudio
OmniAudio

OmniAudio 是一款通过 AI 支持将网页、Word 文档、Gmail 内容、文本片段、视频音频文件都转换为音频播客,并生成可在常见 Podcast ap

下载

saga 模式可以通过两种主要方式实现:

  1. a。 基于编排的 saga: 事务中涉及的每个服务都会侦听事件并执行其事务。完成后,它会发出一个事件来触发传奇中的下一步。如果某个步骤失败,则会触发补偿事件以撤消之前的步骤。

  2. b。 基于编排的 saga: 集中式服务(saga 编排器)协调 saga 的步骤。它确定操作顺序并管理发生故障时的补偿。

2。两阶段提交(2pc): 虽然两阶段提交协议通常用于单体系统,但它可以通过 atomikos 或 bitronix 等分布式事务管理器跨分布式系统使用。但是,我不推荐这种方法,因为它在微服务上下文中存在一些限制,因为它会导致高延迟并且容错能力较差。如果我是你,我通常会避免这种方法,而选择 saga 模式。

3。事件驱动架构: 使用事件驱动方法,服务通过事件进行通信,特别适合处理分布式事务。这种方法与 saga 模式非常吻合。每个服务独立执行其事务,然后发出一个事件以通知其他服务有关结果。这些事件可以使用 apache kafka、rabbitmq 或其他消息代理来处理。

现在,让我们看看它在代码中是如何工作的。

saga 模式有多种风格,但在本文中,我将尝试在 spring boot 中实现基于编排的 saga 模式:

第 1 步: 定义 saga orchestrator:
在这里,我将创建一个简单的服务来充当协调器,负责协调事务。

该服务将定义传奇的流程,以正确的顺序调用每个服务,并在需要时处理补偿事务。

@service
public class ordersagaorchestrator {

    @autowired
    private paymentservice paymentservice;

    @autowired
    private inventoryservice inventoryservice;

    @autowired
    private shippingservice shippingservice;

    public void createordersaga(order order) {
        try {
            paymentservice.processpayment(order.getpaymentdetails());
            inventoryservice.reserveinventory(order.getitems());
            shippingservice.initiateshipping(order.getshippingdetails());
        } catch (exception e) {
            // compensation logic
            shippingservice.cancelshipping(order.getshippingid());
            inventoryservice.releaseinventory(order.getitems());
            paymentservice.refund(order.getpaymentid());
        }
    }
}

第 2 步: 在每个服务中创建本地事务和补偿方法:

每个服务都应该有自己的事务来完成其在传奇中的步骤,并在需要时使用另一个事务来补偿它。这是大概的结构。

@service
public class paymentservice {

    @transactional
    public void processpayment(paymentdetails details) {
        // perform payment logic
    }

    @transactional
    public void refund(string paymentid) {
        // perform refund logic
    }
}

第 3 步: 基于事件的通信(可选,用于编排):每个服务都可以发出事件来通知其他人交易的结果。

public class paymentservice {

    private final applicationeventpublisher eventpublisher;

    public paymentservice(applicationeventpublisher eventpublisher) {
        this.eventpublisher = eventpublisher;
    }

    public void processpayment(paymentdetails details) {
        // process payment
        eventpublisher.publishevent(new paymentprocessedevent(this, details));
    }
}

第 4 步: 采取措施保证数据一致性:使用幂等性检查来确保 saga 中的每个步骤仅执行一次。这在分布式系统中很重要,因为网络故障或重试可能会导致重复请求。

第 5 步: 使用消息代理来提高可靠性:如果您使用事件来管理传奇,可以使用像 rabbitmq 的 kafka 这样的消息代理持久性,并且可以在服务暂时不可用时缓冲事件。

第 6 步: 错误处理和重试: 将错误处理和重试逻辑合并到您的协调器和各个服务中以处理临时故障。 spring retry 在这里很有用,因为它可以在可配置策略中自动重试失败的操作。

@Retryable(value = {RemoteServiceException.class}, maxAttempts = 3, backoff = @Backoff(delay = 2000))
public void reserveInventory(List<Item> items) {
    // Attempt to reserve inventory
}

结论

微服务中的分布式事务具有挑战性,但通过使用 saga(尤其是编排)和事件驱动通信等模式,您可以实现可靠且可扩展的解决方案。

spring boot 通过提供对事务管理、事件发布以及与消息代理集成的支持,使这一切变得更容易。

最后,这个精心策划的传奇确保了 alice 的体验流畅且一致,如果出现任何问题,都会以维护系统完整性的方式解决。这就是微服务中分布式事务和补偿逻辑的魔力。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

161

2025.08.06

Java Spring Security 与认证授权
Java Spring Security 与认证授权

本专题系统讲解 Java Spring Security 框架在认证与授权中的应用,涵盖用户身份验证、权限控制、JWT与OAuth2实现、跨站请求伪造(CSRF)防护、会话管理与安全漏洞防范。通过实际项目案例,帮助学习者掌握如何 使用 Spring Security 实现高安全性认证与授权机制,提升 Web 应用的安全性与用户数据保护。

89

2026.01.26

rabbitmq和kafka有什么区别
rabbitmq和kafka有什么区别

rabbitmq和kafka的区别:1、语言与平台;2、消息传递模型;3、可靠性;4、性能与吞吐量;5、集群与负载均衡;6、消费模型;7、用途与场景;8、社区与生态系统;9、监控与管理;10、其他特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

207

2024.02.23

Java 消息队列与异步架构实战
Java 消息队列与异步架构实战

本专题系统讲解 Java 在消息队列与异步系统架构中的核心应用,涵盖消息队列基本原理、Kafka 与 RabbitMQ 的使用场景对比、生产者与消费者模型、消息可靠性与顺序性保障、重复消费与幂等处理,以及在高并发系统中的异步解耦设计。通过实战案例,帮助学习者掌握 使用 Java 构建高吞吐、高可靠异步消息系统的完整思路。

49

2026.01.28

spring boot框架优点
spring boot框架优点

spring boot框架的优点有简化配置、快速开发、内嵌服务器、微服务支持、自动化测试和生态系统支持。本专题为大家提供spring boot相关的文章、下载、课程内容,供大家免费下载体验。

139

2023.09.05

spring框架有哪些
spring框架有哪些

spring框架有Spring Core、Spring MVC、Spring Data、Spring Security、Spring AOP和Spring Boot。详细介绍:1、Spring Core,通过将对象的创建和依赖关系的管理交给容器来实现,从而降低了组件之间的耦合度;2、Spring MVC,提供基于模型-视图-控制器的架构,用于开发灵活和可扩展的Web应用程序等。

410

2023.10.12

Java Spring Boot开发
Java Spring Boot开发

本专题围绕 Java 主流开发框架 Spring Boot 展开,系统讲解依赖注入、配置管理、数据访问、RESTful API、微服务架构与安全认证等核心知识,并通过电商平台、博客系统与企业管理系统等项目实战,帮助学员掌握使用 Spring Boot 快速开发高效、稳定的企业级应用。

73

2025.08.19

Java Spring Boot 4更新教程_Java Spring Boot 4有哪些新特性
Java Spring Boot 4更新教程_Java Spring Boot 4有哪些新特性

Spring Boot 是一个基于 Spring 框架的 Java 开发框架,它通过 约定优于配置的原则,大幅简化了 Spring 应用的初始搭建、配置和开发过程,让开发者可以快速构建独立的、生产级别的 Spring 应用,无需繁琐的样板配置,通常集成嵌入式服务器(如 Tomcat),提供“开箱即用”的体验,是构建微服务和 Web 应用的流行工具。

152

2025.12.22

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

49

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
RunnerGo从入门到精通
RunnerGo从入门到精通

共22课时 | 1.8万人学习

尚学堂Mahout视频教程
尚学堂Mahout视频教程

共18课时 | 3.3万人学习

Linux优化视频教程
Linux优化视频教程

共14课时 | 3.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号