Spring Cloud Eureka原理分析(一):注册过程-服务端

栏目: Java · 发布时间: 5年前

内容简介: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 则表示一个实例的状态,基本由客户端(服务实例本身)提供。显然,因为服务可能朝生夕死,网络环境千变万化,需要知道服务的状态,决定可不可用。

上一个图,以对 LeaseInstanceInfo 有个初步印象:

Spring Cloud Eureka原理分析(一):注册过程-服务端

2 核心注册过程

AbstractInstanceRegistry#register(...) 方法很长,这里不全部贴出来,否则看得太累。只说一些重要的片段。其余细节以后需要时补充。

  • 首先从registry中找到应用所对应的数据,记为gMap。如果没有,说明之前没有注册过(或被删除了),那就创建一个Map,加到registry中去。
// 以AppName作为应用的ID
Map<String, Lease<InstanceInfo>> gMap = registry.get(registrant.getAppName());
// 如果没有,就创建并添加,略
复制代码
  • 在gMap中找此次注册的实例对应的Lease。 注意应用和实例之间的关系。 如果有,说明之前已经注册成功过,需要使用其中的一些信息,比如 serviceUpTimestamp 等。然后设置lease的 registrationTimestamplastUpdateTimestamp 为当前时间。
  • 经过一个OverriddenInstanceStatus计算,得出此应用实例当前的状态。计算输入包括registry中已有的该实例的lease的状态,和此次注册所声明的状态,以及服务端一系列rule来判断。(同样,这里的细节如有必要以后再讲)最终的InstanceStatus有如下几种状态:
Spring Cloud Eureka原理分析(一):注册过程-服务端
lastUpdatedTimestamp
serviceUpTimestamp
recentlyChangedQueue
invalidateCache()

以上所述就是小编给大家介绍的《Spring Cloud Eureka原理分析(一):注册过程-服务端》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Servlet和JSP学习指南

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在线工具

html转js在线工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具