spring cloud的注册中心是Eureka server。客户端通过http与注册中心交互。
与zookeeper不同,Eureka server集群如果挂掉只剩一台还是能工作的。
而zk的设计目标是一致性,使它用类似paxos协议去实现了。而这样设计的结果是如果zk集群挂掉了整个集群的一半及以上那么整个zk集群就不能工作了。这就是zk的死亡容忍性。举个例子:2台zk,只要挂掉一台就不能工作了,对应死亡容忍度为0。3台为1,4台也为1,5台为2,6台也为2. 因此从资源利用角度,奇数台是最佳的。
以下为注册中心处理注册服务事件简要流程:
做了两件主要的事情:
1.往registry map中放了要注册的服务,registry map的key为appName,
value 为 map<Long,LeaseInfo>
2.如果不是从其它注册中心复制过来的话,需要通过网络传给其它注册中心
核心调用方法:
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);
replicateToPeers(Action.Register, info.getAppName(), info.getId(), info, null, isReplication);
}