【Java面试】又一个简历写精通Spring Cloud !!!结果被问Eureka server数据同步原理

36 篇文章 1 订阅
20 篇文章 3 订阅

一个工作了4年的Java程序员,去一个互联网公司面试,在面试的时候面试官一个劲的

问他Spring Cloud Netflix组件的底层原理,开始还能回答出来,越到后面越懵逼,最后面试没过。

他有点不理解面试官怎么会问这么深,当他把简历发给我的时候,我看到简历上写了精通Spring Cloud。

瞬间明白了原因。

Spring Cloud Netflix里面的组件可以考察的方向太多了,比如今天分享的这道面试题:

“Eureka server数据同步原理”,相信80%的同学都回答不出来,不过没关系,我已经把这个问题的答案整理到了一个10W字的面试文档里面,大家可以在文章尾端扫描二维码领取。

下面看看高手对这个问题的回答。

高手

Eureka是一个服务注册中心,在Eureka的设计里面,为了保证Eureka的高可用性,提供了集群的部署方式。

Eureka的集群部署采用的是两两相互注册的方式来实现,也就是说每个Eureka Server节点都需要发现集群中的其他节点并建立连接,然后通过心跳的方式来维持这个连接的状态。

Eureka Server集群节点之间的数据同步方式非常简单粗暴,使用的是对等复制的方式来实现数据同步。

也就是说,在Eureka Server集群中,不存在所谓主从节点,任何一个节点都可以接收或者写入数据。

一旦集群中的任意一个节点接收到了数据的变更,就直接同步到其他节点上。

这种无中心化节点的数据同步,需要考虑到一个数据同步死循环的问题,也就是需要区分Eureka Server收到的数据是属于客户端传递来的数据还是集群中其他节点发过来的同步数据。

Eureka使用了一个时间戳的标记来实现类似于数据的版本号来解决这个问题。

另外,从Eureka的数据同步方案来看,Eureka集群采用的是AP模型,也就是只提供高可用保障,而不提供数据强一致性保障。

之所以采用AP,我认为注册中心它只是维护服务之间的通信地址,数据是否一致对于服务之间的通信影响并不大。

而注册中心对Eureka的高可用性要求会比较高,不能出现因为Eureka的故障导致服务之间无法通信的问题。

总结

Eureka虽然闭源了,但是在国内依然使用较为广泛。

当然有些公司逐步迁移到了Nacos上面,但是Eureka的整个框架设计上还是有非常多值得我们学习的思想。

多级缓存设计、集群之间的数据同步方案、多区域隔离以及就近访问的设计等等。

一个技术框架,我们 能够获得这些优秀理念,对未来的职业发展帮助是非常大的。

另外,我将所有Java面试系列制作成了完整的面试文档。它的便捷之处在于,可以通过检索的方式,找到你想要的面试题,目前已经更新200期,总计超过20W字!

【想领取面试文档的小伙伴可以点击文章底部名片无套路免费赠送给大家!】

需要高手面试文档面试文档的小伙伴可以扫描下方二维码
↓↓↓↓↓↓↓↓↓↓↓↓↓

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

跟着Mic学架构

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值