0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

什么是业务补偿?业务补偿设计的实现方式

jf_ro2CN3Fa 来源:栗筝i 2023-04-10 10:01 次阅读

我们知道,应用系统在分布式的情况下,在通信时会有着一个显著的问题,即一个业务流程往往需要组合一组服务,且单单一次通信可能会经过 DNS 服务,网卡、交换机、路由器、负载均衡等设备,而这些服务于设备都不一定是一直稳定的,在数据传输的整个过程中,只要任意一个环节出错,都会导致问题的产生。

这样的事情在微服务下就更为明显了,因为业务需要在一致性上的保证。也就是说,如果一个步骤失败了,要么不断重试保证所有的步骤都成功,要么回滚到以前的服务调用。

因此我们可以对业务补偿的过程进行一个定义,即当某个操作发生了异常时,如何通过内部机制将这个异常产生的「不一致」状态消除掉。

一、关于业务补偿机制

1、什么是业务补偿

我们知道,应用系统在分布式的情况下,在通信时会有着一个显著的问题,即一个业务流程往往需要组合一组服务,且单单一次通信可能会经过 DNS 服务,网卡、交换机、路由器、负载均衡等设备,而这些服务于设备都不一定是一直稳定的,在数据传输的整个过程中,只要任意一个环节出错,都会导致问题的产生。

这样的事情在微服务下就更为明显了,因为业务需要在一致性上的保证。也就是说,如果一个步骤失败了,要么不断重试保证所有的步骤都成功,要么回滚到以前的服务调用。

因此我们可以对业务补偿的过程进行一个定义,即当某个操作发生了异常时,如何通过内部机制将这个异常产生的「不一致」状态消除掉。

2、业务补偿设计的实现方式

业务补偿设计的实现方式主要可分为两种:

回滚(事务补偿) ,逆向操作,回滚业务流程,意味着放弃,当前操作必然会失败;

重试 ,正向操作,努力地把一个业务流程执行完成,代表着还有成功的机会。

一般来说,业务的事务补偿都是需要一个工作流引擎的。这个工作流引擎把各式各样的服务给串联在一起,并在工作流上做相应的业务补偿,整个过程设计成为最终一致性的。

Ps:因为「补偿」已经是一个额外流程了,既然能够走这个额外流程,说明时效性并不是第一考虑的因素。所以做补偿的核心要点是:宁可慢,不可错。

二、关于回滚

“回滚” 是指当程序或数据出错时,将程序或数据恢复到最近的一个正确版本的行为。在分布式业务补偿设计到的回滚则是通过事务补偿的方式,回到服务调用以前的状态。

1、显示回滚

回滚一般可分为 2 种模式:

显式回滚 ;调用逆向接口,进行上一次操作的反操作,或者取消上一次还没有完成的操作(须锁定资源);

隐式回滚 :隐式回滚意味着这个回滚动作你不需要进行额外处理,往往是由下游提供了失败处理机制的。

最常见的就是「显式回滚」。这个方案无非就是做 2 个事情:

首先要确定失败的步骤和状态,从而确定需要回滚的范围。一个业务的流程,往往在设计之初就制定好了,所以确定回滚的范围比较容易。但这里唯一需要注意的一点就是:如果在一个业务处理中涉及到的服务并不是都提供了「回滚接口」,那么在编排服务时应该把提供「回滚接口」的服务放在前面,这样当后面的工作服务错误时还有机会「回滚」。

其次要能提供「回滚」操作使用到的业务数据。「回滚」时提供的数据越多,越有益于程序的健壮性。因为程序可以在收到「回滚」操作的时候可以做业务的检查,比如检查账户是否相等,金额是否一致等等。

2、回滚的实现方式

对于跨库的事务,比较常见的解决方案有:两阶段提交、三阶段提交(ACID)但是这 2 种方式,在高可用的架构中一般都不可取,因为跨库锁表会消耗很大的性能。

高可用的架构中一般不会要求强一致性,只要达到最终的一致性就可以了。可以考虑:事务表、消息队列、补偿机制、TCC 模式(占位 / 确认或取消)、Sagas模式(拆分事务 + 补偿机制)来实现最终的一致性。

三、关于重试

“重试” 的语义是我们认为这个故障是暂时的,而不是永久的,所以,我们会去重试。这个操作最大的好处就是不需要提供额外的逆向接口。这对于代码的维护和长期开发的成本有优势,而且业务是变化的。逆向接口也需要变化。所以更多时候可以考虑重试。

1、重试的使用场景

相较于回滚,重试使用的场景要少一些:下游系统返回请求超时,被限流中等临时状态的时候,我们就可以考虑重试了。而如果是返回余额不足,无权限的明确业务错误,就不需要重试。一些中间件或者 RPC 框架,返回 503,404 这种没有预期恢复时间的错误,也不需要重试了。

2、重试策略

重试的时间和重试的次数。这种在不同的情况下要有不同的考量,主流的重试策略主要是以下几种:

策略 1 - 立即重试 :有时候故障是暂时性的,可能因为网络数据包冲突或者硬件组件高峰流量等事件造成的,在这种情况下,适合立即重试的操作。不过立即重试的操作不应该超过一次,如果立即重试失败,应该改用其他策略;

策略 2 - 固定间隔 :这个很好理解,比如每隔 5 分钟重试一次。PS:策略 1 和策略 2 多用于前端系统的交互操作中;

策略 3 - 增量间隔 :每一次的重试间隔时间增量递增。比如,第一次 0 秒、第二次 5 秒、第三次 10 秒这样,使得失败次数越多的重试请求优先级排到越后面,给新进入的重试请求让路;

return(retryCount-1)*incrementInterval;

策略 4 - 指数间隔: 每一次的重试间隔呈指数级增加。和增量间隔一样,都是想让失败次数越多的重试请求优先级排到越后面,只不过这个方案的增长幅度更大一些;

return2^retryCount;

策略 5 - 全抖动: 在递增的基础上,增加随机性(可以把其中的指数增长部分替换成增量增长。)适用于将某一时刻集中产生的大量重试请求进行压力分散的场景;

returnrandom(0,2^retryCount);

策略 6 - 等抖动: 在「指数间隔」和「全抖动」之间寻求一个中庸的方案,降低随机性的作用。适用场景和「全抖动」一样。

intbaseNum=2^retryCount;
returnbaseNum+random(0,baseNum);

策略 - 3、4、5、6 的表现情况大致是这样(x轴为重试次数):

882edae4-d6c8-11ed-bfe3-dac502259ad0.png

3、重试时的注意事项

首先对于需要重试的接口,是需要做成幂等性的,即不能因为服务的多次调用而导致业务数据的累计增加或减少。

满足「幂等性」其实就是需要想办法识别重复的请求,并且将其过滤掉。思路就是:

给每个请求定义一个唯一标识。

在进行「重试」的时候判断这个请求是否已经被执行或者正在被执行,如果是则抛弃该请求。

Ps:此外重试特别适合在高负载情况下被降级,当然也应当受到限流和熔断机制的影响。当重试的“矛”与限流和熔断的“盾”搭配使用,效果才是最好。

四、业务补偿机制的注意事项

1、ACID 还是 BASE

ACID 和 BASE 是分布式系统中两种不同级别的一致性理论,在分布式系统中,ACID有更强的一致性,但可伸缩性非常差,仅在必要时使用;BASE的一致性较弱,但有很好的可伸缩性,还可以异步批量处理;大多数分布式事务适合 BASE。

而在重试或回滚的场景下,我们一般不会要求强一致性,只要保证最终一致性就可以了!

2、业务补偿设计的注意事项

业务补偿设计的注意事项:

因为要把一个业务流程执行完成,需要这个流程中所涉及的服务方支持幂等性。并且在上游有重试机制;

我们需要小心维护和监控整个过程的状态,所以,千万不要把这些状态放到不同的组件中,最好是一个业务流程的控制方来做这个事,也就是一个工作流引擎。所以,这个工作流引擎是需要高可用和稳定的;

补偿的业务逻辑和流程不一定非得是严格反向操作。有时候可以并行,有时候,可能会更简单。总之,设计业务正向流程的时候,也需要设计业务的反向补偿流程;

我们要清楚地知道,业务补偿的业务逻辑是强业务相关的,很难做成通用的;

下层的业务方最好提供短期的资源预留机制。就像电商中的把货品的库存预先占住等待用户在 15 分钟内支付。如果没有收到用户的支付,则释放库存。然后回滚到之前的下单操作,等待用户重新下单。






审核编辑:刘清

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 数据传输
    +关注

    关注

    9

    文章

    1919

    浏览量

    64671
  • 交换机
    +关注

    关注

    21

    文章

    2645

    浏览量

    99775
  • 路由器
    +关注

    关注

    22

    文章

    3734

    浏览量

    113977
  • DNS
    DNS
    +关注

    关注

    0

    文章

    218

    浏览量

    19871

原文标题:浅谈分布式系统中的补偿机制设计问题

文章出处:【微信号:芋道源码,微信公众号:芋道源码】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    饱和蒸汽流量计测量时补偿方式的选择

    在饱和蒸汽流量测量中,补偿方式的选择是确保测量准确性的关键。由于饱和蒸汽的密度与温度或压力之间存在固定的对应关系,因此可以通过温度补偿或压力补偿来修正测量结果。对于饱和蒸汽来说,可以只
    的头像 发表于 12-29 09:38 79次阅读

    突破传统监测模式:业务状态监控HM的新思路

    一、传统监控系统的盲区,如何打造业务状态监控。 在系统架构设计中非常重要的一环是要做数据监控和数据最终一致性,关于一致性的补偿,已经由算法部的大佬总结过就不在赘述。这里主要讲如何去补偿补偿
    的头像 发表于 08-29 14:36 238次阅读
    突破传统监测模式:<b class='flag-5'>业务</b>状态监控HM的新思路

    电容半补偿和全补偿的区别

    电容半补偿和全补偿是两种不同的无功补偿方式,主要区别在于补偿的程度和效果。以下是它们的具体区别: 1、
    的头像 发表于 08-14 14:08 925次阅读
    电容半<b class='flag-5'>补偿</b>和全<b class='flag-5'>补偿</b>的区别

    无功补偿随机补偿和随器补偿的区别

    无功补偿的随机补偿和随器补偿是两种不同的补偿策略,它们在应用场景、控制方法和效果上存在差异。 一、随机补偿 1、概述 随机
    的头像 发表于 07-18 14:20 819次阅读
    无功<b class='flag-5'>补偿</b>随机<b class='flag-5'>补偿</b>和随器<b class='flag-5'>补偿</b>的区别

    llc电源环路补偿是几阶补偿

    LLC电源环路补偿是电源设计中的一个重要环节,其目的是保证电源系统的稳定性和性能。LLC电源环路补偿通常采用二阶补偿或更高阶补偿,具体取决于电源系统的需求和设计。 LLC电源环路
    的头像 发表于 07-16 16:19 1263次阅读

    并联电容器的补偿方式有哪几种

    。 固定补偿 固定补偿是最简单的一种补偿方式,它通过安装一组固定容量的并联电容器来实现。这种方式
    的头像 发表于 07-12 14:50 837次阅读

    无功补偿怎么计算补偿电容容量

    无功补偿是电力系统中一种重要的技术手段,用于提高电网的功率因数,降低线损,提高输电效率,改善电能质量。无功补偿的主要方式是通过并联电容器进行补偿。本文将介绍无功
    的头像 发表于 07-12 14:44 1619次阅读

    无功补偿方式有哪几种类型

    无功补偿是电力系统中提高功率因数、改善电网质量、减少线路损失的重要技术手段。根据补偿装置的接入电压等级和安装位置的不同,无功补偿方式可以分为高压分散
    的头像 发表于 06-09 16:50 1259次阅读

    无功补偿的装设方式有哪些

    无功补偿是电力系统中维持电压稳定、提高功率因数、减少能量损失及保障电网安全高效运行的重要技术手段。正确安排无功补偿对于优化电力系统性能至关重要。以下是几种常见的无功补偿安排方式: 1.
    的头像 发表于 06-09 15:00 790次阅读

    无功补偿装置的安装方式

    无功补偿装置的安装方式通常根据具体的应用场景和电力系统的需求来决定,以下是一些常见的安装方式及其特点:
    的头像 发表于 04-24 14:18 598次阅读

    无功补偿器怎么调到自动补偿

    无功补偿器是一种重要的电力设备,它可以对电力系统中的无功功率进行补偿调节,提高电力系统的功率因数。正确调节无功补偿器的自动补偿功能,可以有效地解决电力系统中的无功功率问题,提高电力系统
    的头像 发表于 04-24 14:16 938次阅读

    无功补偿控制器怎么设置参数 无功补偿的作用和原理

    无功补偿控制器是一种用于调节电力系统的无功功率的设备,通过设置参数,可以实现对电网的无功功率进行精确控制。本文将详细介绍无功补偿的作用和原理,以及如何设置无功补偿控制器的参数。 一、无
    的头像 发表于 02-01 16:44 5464次阅读

    静止无功补偿与动态无功补偿有哪些区别呢?

    静止无功补偿与动态无功补偿有哪些区别呢? 静止无功补偿和动态无功补偿是电力系统中常用的无功补偿技术,两者在原理、应用和效果等方面有着明显的区
    的头像 发表于 01-23 16:28 3625次阅读

    无功补偿的原理、作用及常见方式

    无功补偿的原理、作用及常见方式  无功补偿是电力系统中的一项重要技术措施,用于改善电力质量和提高能源利用效率。本文将详细介绍无功补偿的原理、作用以及常见的
    的头像 发表于 01-19 14:19 9386次阅读

    如何根据补偿原则,确定无功补偿容量?

    如何根据补偿原则,确定无功补偿容量? 补偿原则是电力系统中的一个重要原理,其目的是通过引入无功补偿容量来改善电网的功率因数和电压质量,提高系统的稳定性和可靠性。 第一部分:无功
    的头像 发表于 01-19 14:19 965次阅读