突破Java面试(39)-分布式服务接口请求的顺序性
1 面试题
分布式服务接口请求的顺序性如何保证?
2 考点分析
分布式系统接口的调用顺序,一般来说是不用保证的.
但是有时候可能确实需要严格的顺序保证.
举个例子:
服务 A 调用服务 B,先插入再删除。好,结果俩请求过去了,落在不同机器上,可能插入请求因为某些原因执行慢了一些,导致删除请求先执行了,此时因为没数据所以啥效果也没有;结果这个时候插入请求过来了,好,数据插入进去了,尴尬咯~
本该 “先插入 => 再删除”,这条数据应该没了,结果现在 “先删除 => 再插入”,数据还存在!
所以这都是分布式系统一些很常见的问题。
3 解决方案
一般来说,建议从业务逻辑上设计的系统最好是不需要这种顺序性的保证,因为一旦引入顺序性保障,比如使用分布式锁,会导致系统复杂度上升,而且会带来效率低下,热点数据压力过大等问题。
简单来说,首先你得用 Dub