分布式服务接口请求的顺序性如何保证?
2019-05-27 21:03
405 查看
版权声明:~转载请标注,谢谢~如果侵权了请私信我,我会立刻删除~ https://blog.csdn.net/baidu_26954625/article/details/90611826
面试题剖析
首先,一般来说,个人建议是,你们从业务逻辑上设计的这个系统最好是不需要这种顺序性的保证,因为一旦引入顺序性保障,比如使用分布式锁,会导致系统复杂度上升,而且会带来效率低下,热点数据压力过大等问题。
本博客转自git项目advancejava
面试题剖析
首先,一般来说,个人建议是,你们从业务逻辑上设计的这个系统最好是不需要这种顺序性的保证,因为一旦引入顺序性保障,比如使用分布式锁,会导致系统复杂度上升,而且会带来效率低下,热点数据压力过大等问题。
下面我给个我们用过的方案吧,简单来说,首先你得用 dubbo 的一致性 hash 负载均衡策略,将比如某一个订单 id 对应的请求都给分发到某个机器上去,接着就是在那个机器上因为可能还是多线程并发执行的,你可能得立即将某个订单 id 对应的请求扔一个内存队列里去,强制排队,这样来确保他们的顺序性。
但是这样引发的后续问题就很多,比如说要是某个订单对应的请求特别多,造成某台机器成热点怎么办?解决这些问题又要开启后续一连串的复杂技术方案…曾经这类问题弄的我们头疼不已,所以,还是建议什么呢?
最好是比如说刚才那种,一个订单的插入和删除操作,能不能合并成一个操作,就是一个删除,或者是什么,避免这种问题的产生。
相关文章推荐
- app接口,如何保证是由app内部调用而非外部模拟post请求调用。
- java分布式系统定时任务,如何保证多台服务只执行一次
- 分布式高并发系统如何保证对外接口的幂等性
- ASP.NET WebApi服务接口如何防止重复请求实现HTTP幂等性
- ASP.NET WebApi服务接口如何防止重复请求实现HTTP幂等性(八)
- 如何保证微服务接口的幂等性
- 分布式高并发系统如何保证对外接口的幂等性?
- 如何保证微服务接口的幂等性
- 39 分布式系统中接口的幂等性该如何保证?比如不能重复扣款?
- 分布式高并发系统如何保证对外接口的幂等性?
- 40 分布式系统中的接口调用如何保证顺序性?
- 如何保证HTTP接口请求的安全呢?
- 如何保证微服务接口的幂等性
- 如何在Spring Boot中,使用Https提供服务,并将Http请求自动重定向到Https。
- 如何避免不同的用户调用接口时出现多个服务程序实例
- 如何用 redis 实现分布式幂等服务中间件
- 交易系统的消息服务如何保证100%可靠
- PHP做APP接口时,如何保证接口的安全性??????????
- 如何改变WINDOWS服务的启动顺序(Win2000)
- WCF分布式开发常见错误解决(12):The server was unable to process the request,服务无法处理请求