image

编辑人: 沉寂于曾经

calendar2025-02-04

message5

visits781

分布式系统中的接口调用如何保证顺序性?

分析&回答

一般来说是不用保证顺序的。但是有的时候可能确实是需要严格的顺序保证。给大家举个例子,你服务A调用服务B,先插入 -> 再删除。可能会变成先删除 -> 再插入。

怎么破圈

  1. 业务逻辑上解决。一般来说,从业务逻辑上最好设计系统不需要这种顺序的保证,因为一旦引入顺序性保障,会导致系统复杂度的上升,效率会降低,对于热点数据会压力过大等问题。
  2. 操作串行化。首先使用一致性hash负载均衡策略,将同一个id的请求都分发到同一个机器上面去处理,比如订单可以根据订单id。如果处理的机器上面是多线程处理的,可以引入内存队列去处理,将相同id的请求通过hash到同一个队列当中,一个队列只对应一个处理线程。
  3. 设计上解决。最好能将多个操作合并成一个操作。
  4. 幂等排他发。在一个操作进入未执行完成之前,禁止第二个操作。

反思&扩展

优先通过业务的维度去解决问题,实在没法处理的情况下再通过技术折中处理。


喵呜面试助手: 一站式解决面试问题,你可以搜索微信小程序 [喵呜面试助手] 或关注 [喵呜刷题] -> 面试助手 免费刷题。如有好的面试知识或技巧期待您的共享!

创作类型:
原创

本文链接:分布式系统中的接口调用如何保证顺序性?

版权声明:本站点所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明文章出处。
分享文章
share