Eureka的官方文档和Spring Cloud Eureka文档都有很多含糊的地方,其他资料也不多,只有读读源码维持生活这样子……
本文将不会详细介绍每个细节,而是讲述一些关键的地方,便于查阅。
正常情况下会进入 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(...)
方法完成注册,再将这个注册信息复制到同伴节点。
我们先来看注册部分。
registry在 AbstractInstanceRegistry
中声明:
private final ConcurrentHashMap<String, Map<String, Lease<InstanceInfo>>> registry; 复制代码
它就是一个ConcurrentHashMap, 其Key为应用的AppID,Value为一个Map,其中的键值对为该应用的各个实例。(InstanceId为键, Lease<InstanceInfo>>
为值)
Lease
表示一个应用实例(Instance)的注册期限,有租约到期和续租之说。 InstanceInfo
则表示一个实例的状态,基本由客户端(服务实例本身)提供。显然,因为服务可能朝生夕死,网络环境千变万化,需要知道服务的状态,决定可不可用。
上一个图,以对 Lease
和 InstanceInfo
有个初步印象:
AbstractInstanceRegistry#register(...)
方法很长,这里不全部贴出来,否则看得太累。只说一些重要的片段。其余细节以后需要时补充。
// 以AppName作为应用的ID Map<String, Lease<InstanceInfo>> gMap = registry.get(registrant.getAppName()); // 如果没有,就创建并添加,略 复制代码
serviceUpTimestamp
等。然后设置lease的 registrationTimestamp
和 lastUpdateTimestamp
为当前时间。 lastUpdatedTimestamp serviceUpTimestamp recentlyChangedQueue invalidateCache()