【服务Provider】在进程启动时,会注册服务到【注册中心】,并每隔一段时间,汇报心跳给【注册中心】,通知自己的存活状态。
若隔了一段固定时间后,【服务Provider】仍没有汇报心跳给【注册中心】,【注册中心】就会认为该节点已死,将其从可用节点中移除。
若遇到网络问题,大批【服务Provider】节点汇报给【注册中心】的心跳信息都可能会传达失败,【注册中心】就会把它们都从可用节点列表中移除,造成剩下可用节点难以承受所有调用,引起“雪崩”。但这种情况下,可能大部分服务提供者节点是可用的,仅因为网络原因无法汇报心跳给注册中心就被“无情”摘除。
这就需要根据实际业务,设定一个阈值比例,即使网络抖动,【注册中心】也不能摘除超过这个阈值比例的节点。通常设定在20%。因为绝大部分时间,节点变化也不会变化频繁,只有在如下情况才可能发生:
- 业务明确要下线大批节点
这种情况又是可预知的,所以可以关闭阈值保护。
- 网络抖动
一般正常时,应打开阈值保护,以防网络抖动时,大批量可用服务节点被摘除。
综上,该机制是为避免【服务Provider】节点被大量摘除,而导致【服务Consumer】可调用节点不足。
所以这两种机制,都是因为【注册中心】的节点信息瞬息万变,所以也经常把【注册中心】称为【动态注册中心】。
我开始疑惑了,那是否能另辟蹊径,【服务Consumer】并不严格以【注册中心】中的服务节点信息为准,而是更多的以【服务Consumer】实际调用信息来判断【服务Provider】是否可用呢?
有的,这就是静态注册中心。
心跳机制能保证在【服务Provider】出现异常时,【注册中心】可以及时把不可用的【服务Provider】从可用节点列表中移除,这很好。
但仔细思考,为何不把这种心跳机制直接用在【服务Consumer】?
因为【服务Provider】是向【服务Consumer】提供服务,是否可用【服务Consumer】应该比【注册中心】更清楚,因此可直接在【服务消费者】端根据调用【服务Provider】是否成功,以判定服务Provider】是否可用。
若【服务Consumer】调用某一【服务Provider】连续失败超过一定次数,可在本地内存将该节点标记为不可用。
每隔一段固定时间,【服务Consumer】向标记为不可用的节点发起保活探测,若探测成功,就将标记为不可用的节点再恢复为可用态,重新发起调用。
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
复习的面试资料
这些面试全部出自大厂面试真题和面试合集当中,小编已经为大家整理完毕(PDF版)
- 第一部分:Java基础-中级-高级
- 第二部分:开源框架(SSM:Spring+SpringMVC+MyBatis)
- 第三部分:性能调优(JVM+MySQL+Tomcat)
- 第四部分:分布式(限流:ZK+Nginx;缓存:Redis+MongoDB+Memcached;通讯:MQ+kafka)
- 第五部分:微服务(SpringBoot+SpringCloud+Dubbo)
- 第六部分:其他:并发编程+设计模式+数据结构与算法+网络
进阶学习笔记pdf
- Java架构进阶之架构筑基篇(Java基础+并发编程+JVM+MySQL+Tomcat+网络+数据结构与算法)
- Java架构进阶之开源框架篇(设计模式+Spring+SpringMVC+MyBatis)
- Java架构进阶之分布式架构篇 (限流(ZK/Nginx)+缓存(Redis/MongoDB/Memcached)+通讯(MQ/kafka))
- Java架构进阶之微服务架构篇(RPC+SpringBoot+SpringCloud+Dubbo+K8s)
一个人可以走的很快,但一群人才能走的更远。如果你从事以下工作或对以下感兴趣,欢迎戳这里加入程序员的圈子,让我们一起学习成长!
AI人工智能、Android移动开发、AIGC大模型、C C#、Go语言、Java、Linux运维、云计算、MySQL、PMP、网络安全、Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算
算、MySQL、PMP、网络安全、Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算**