springCloud注册中心处理注册事件

  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);
    }


  

  

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值