内容简介:Eureka的官方文档和Spring Cloud Eureka文档都有很多含糊的地方,其他资料也不多,只有读读源码维持生活这样子……本文将不会详细介绍每个细节,而是讲述一些关键的地方,便于查阅。正常情况下会进入
Eureka的官方文档和Spring Cloud Eureka文档都有很多含糊的地方,其他资料也不多,只有读读源码维持生活这样子……
本文将不会详细介绍每个细节,而是讲述一些关键的地方,便于查阅。
一些好的参考资料
Eureka-Server接受注册请求
正常情况下会进入 PeerAwareInstanceRegistryImpl#register(...)
方法:
@Override public void register(final InstanceInfo info, final boolean isReplication) { // 租约过期时间 int leaseDuration = Lease.DEFAULT_DURATION_IN_SECS; if (info.getLeaseInfo() != null && info.getLeaseInfo().getDurationInSecs() > 0) { leaseDuration = info.getLeaseInfo().getDurationInSecs(); } // 注册应用实例信息 super.register(info, leaseDuration, isReplication); // Eureka-Server 复制 replicateToPeers(Action.Register, info.getAppName(), info.getId(), info, null, isReplication); } 复制代码
先调用父类 AbstractInstanceRegistry#register(...)
方法完成注册,再将这个注册信息复制到同伴节点。
我们先来看注册部分。
1 注册表registry的实际结构
registry在 AbstractInstanceRegistry
中声明:
private final ConcurrentHashMap<String, Map<String, Lease<InstanceInfo>>> registry; 复制代码
它就是一个ConcurrentHashMap, 其Key为应用的AppID,Value为一个Map,其中的键值对为该应用的各个实例。(InstanceId为键, Lease<InstanceInfo>>
为值)
Lease
表示一个应用实例(Instance)的注册期限,有租约到期和续租之说。 InstanceInfo
则表示一个实例的状态,基本由客户端(服务实例本身)提供。显然,因为服务可能朝生夕死,网络环境千变万化,需要知道服务的状态,决定可不可用。
上一个图,以对 Lease
和 InstanceInfo
有个初步印象:
2 核心注册过程
AbstractInstanceRegistry#register(...)
方法很长,这里不全部贴出来,否则看得太累。只说一些重要的片段。其余细节以后需要时补充。
- 首先从registry中找到应用所对应的数据,记为gMap。如果没有,说明之前没有注册过(或被删除了),那就创建一个Map,加到registry中去。
// 以AppName作为应用的ID Map<String, Lease<InstanceInfo>> gMap = registry.get(registrant.getAppName()); // 如果没有,就创建并添加,略 复制代码
- 在gMap中找此次注册的实例对应的Lease。 注意应用和实例之间的关系。 如果有,说明之前已经注册成功过,需要使用其中的一些信息,比如
serviceUpTimestamp
等。然后设置lease的registrationTimestamp
和lastUpdateTimestamp
为当前时间。 - 经过一个OverriddenInstanceStatus计算,得出此应用实例当前的状态。计算输入包括registry中已有的该实例的lease的状态,和此次注册所声明的状态,以及服务端一系列rule来判断。(同样,这里的细节如有必要以后再讲)最终的InstanceStatus有如下几种状态:
lastUpdatedTimestamp serviceUpTimestamp recentlyChangedQueue invalidateCache()
以上所述就是小编给大家介绍的《Spring Cloud Eureka原理分析(一):注册过程-服务端》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- React 服务端渲染原理及过程
- Elasticsearch 架构原理—— 新数据写入过程
- S2-057原理分析与复现过程(POC)
- MS08-067漏洞原理及详尽分析过程
- Flink SQL 演进过程,解析原理及一些优化策略
- 面试问烂的Spring AOP原理、SpringMVC过程
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Servlet和JSP学习指南
Budi Kurniawan / 崔毅、俞哲皆、俞黎敏 / 机械工业出版社华章公司 / 2013-4-14 / 59.00元
本书是系统学习Servlet和JSP的必读之作。由全球知名的Java技术专家(《How Tomcat Works》作者)亲自执笔,不仅全面解读Servlet 和JSP 的最新技术,重点阐述Java Web开发的重要编程概念和设计模型,而且包含大量可操作性极强的案例。 本书共18章:第1章介绍Servlet API和几个简单的Servlet;第2章讨论Session追踪,以及保持状态的4种技术......一起来看看 《Servlet和JSP学习指南》 这本书的介绍吧!
html转js在线工具
html转js在线工具
HEX HSV 转换工具
HEX HSV 互换工具