专栏首页JavaEdge突破Java面试(39)-分布式服务接口请求的顺序性
原创

突破Java面试(39)-分布式服务接口请求的顺序性

1 面试题

分布式服务接口请求的顺序性如何保证?

2 考点分析

分布式系统接口的调用顺序,一般来说是不用保证的.

但是有时候可能确实需要严格的顺序保证.

举个例子:

服务 A 调用服务 B,先插入再删除。好,结果俩请求过去了,落在不同机器上,可能插入请求因为某些原因执行慢了一些,导致删除请求先执行了,此时因为没数据所以啥效果也没有;结果这个时候插入请求过来了,好,数据插入进去了,尴尬咯~

本该 “先插入 => 再删除”,这条数据应该没了,结果现在 “先删除 => 再插入”,数据还存在!

所以这都是分布式系统一些很常见的问题。

3 解决方案

一般来说,建议从业务逻辑上设计的系统最好是不需要这种顺序性的保证,因为一旦引入顺序性保障,比如使用分布式锁,会导致系统复杂度上升,而且会带来效率低下热点数据压力过大等问题。

简单来说,首先你得用 Dubbo 的一致性 hash 负载均衡策略,将比如某一个订单 id 对应的请求都给分发到某个机器上去,接着就是在那个机器上因为可能还是多线程并发执行的,你可能得立即将某个订单 id 对应的请求扔一个内存队列里去,强制排队,来确保他们的顺序性

  • 分布式系统接口调用顺序性图示

但是这样引发的后续问题就很多!

比如说要是某个订单对应的请求特别多,造成某台机器成热点怎么办?解决这些问题又要开启后续一连串的复杂技术方案......曾经这类问题弄的我们头疼不已,所以,还是建议什么呢?

最好是比如说刚才那种,一个订单的插入和删除操作,能不能合并成一个操作,就是一个删除,或者是什么,避免这种问题的产生。

参考

  • 《Java工程师面试突击第1季-中华石杉老师》Github

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • ZooKeeper 原理与服务器集群部署

    ZooKeeper 是大型分布式系统中可靠的协调系统,它以树状结构存储数据,以领导选举和信息同步机制保证了集群的高可用性,以事件通知机制协助事件订阅者及时捕获数...

    IT技术小咖
  • 002.Ceph安装部署

    Ceph Monitors之间默认使用6789端口通信,OSD之间默认用6800:7300范围内的端口通信。Ceph OSD能利用多个网络连接进行与客户端、mo...

    木二
  • 高并发下为什么更喜欢进程内缓存

    进程内缓存是指缓存和应用程序在相同地址空间。即同一个进程内。分布式缓存是指缓存和应用程序位于不同进程的缓存,通常部署在不同服务器上。

    Java_老男孩
  • 浅谈高并发下接口幂等性解决方案

    在编程中.一个幂等操作的特点是其任意多次执行所产生的影响均与一次执行的影响相同。幂等函数,或幂等方法,是指可以使用相同参数重复执行,并能获得相同结果的函数。这些...

    IT技术小咖
  • Spring Boot Quartz 分布式集群任务调度实

    在工程中时常会遇到一些需求,例如定时刷新一下配置、隔一段时间检查下网络状态并发送邮件等诸如此类的定时任务。 定时任务本质就是一个异步的线程,线程可以查询或修改并...

    乱敲代码
  • JAVA高并发 Redis+Lua限流实战

    但是我们也知道,限流器在每次请求令牌和放入令牌操作中,存在一个协同的问题,即获取令牌操作要尽可能保证原子性,否则无法保证限流器是否能正常工作。在RateLimi...

    小东啊
  • SpringBoot 2.x ShardingSphere分库分表实战

    在之前我做项目的时候,数据量比较大,单表千万级别的,需要分库分表,于是在网上搜索这方面的开源框架,最常见的就是mycat,sharding-sphere,最终我...

    小东啊
  • 观察者模式

    观察者模式还算一个比较好玩的设计模式,其实就是发布订阅模式,发布者发布信息,订阅者获取信息,订阅了就能收到信息,没订阅就收不到信息。可以想象成消息中间件在系统中...

    胖虎
  • Redis实现分布式锁的正确方式

    封面为好友拍摄的照片,想查看更多微信公众号搜索:JavaBoy王皓或csdn博客搜索:TenaciousD

    胖虎
  • Redis集群实现分布式锁的正确方式

    上文我们介绍的 Redis实现分布式锁的正确方式 是 redis 单机的方式,所以本篇要基于 redis 集群做分布式锁,我们使用 Redisson

    胖虎

扫码关注云+社区

领取腾讯云代金券