Nacos源码阅读系列2(心跳机制及健康监测)

服务注册

前面已经准备了源码环境

谈及Nacos,服务注册中心不可不提及
问题1: 服务注册流程(服务端处理逻辑)
问题2:客户端心跳机制及服务端的健康检测
注册成功后客户端默认每隔五秒发一次心跳,接口:InstanceController( /v1/ns/beat)
服务端在客户端注册过程中,会创建定时任务去检查lastHeartBeatTime,默认情况下,超15秒,将服务置为不健康,超30s,删除客户端服务

入口:nacos-naming模块提供api接口:(InstanceController.register) /v1/ns/instance

        getInstanceOperator().registerInstance(namespaceId, serviceName, instance);
        //方法内重要代码(下面一一说明)
        createIpPortClientIfAbsent(clientId);//code_1
        Service service = getService(namespaceId, serviceName, ephemeral);//code_2
        clientOperationService.registerInstance(service, instance, clientId);//code_3
  1. code_1
    createIpPortClientIfAbsent(clientId);//code_1
    作用:创建一个客户端,并添加到定时任务中定时(默认5s)检测客户端状态,实现健康检测
    实现原理:客户端默认五秒发一次心跳,服务端会更新字段lastHeartBeatTime,默认情况下,超15s,置为不健康,instance.setHealthy(false);,超30秒,删除客户端服务,client.removeServiceInstance(service);
    在这里插入图片描述
  2. code_2
    Service service = getService(namespaceId, serviceName, ephemeral);//code_2
    此处构建一个Service对象,暂不做解释,其结构为:
    在这里插入图片描述
  3. code_3
    clientOperationService.registerInstance(service, instance, clientId);//code_3
        Service singleton = ServiceManager.getInstance().getSingleton(service);//code_3.1
        
        client.addServiceInstance(singleton, instanceInfo);//code_3.2

code_3.1
先了解服务端如何保存客户端服务的(结构如下,图片引用
在这里插入图片描述
相关代码:ServiceManager

	//保存客户端服务容器
	private final ConcurrentHashMap<Service, Service> singletonRepository;
    
    //通过key做环境隔离 key:Service.getNamespace()
    private final ConcurrentHashMap<String, Set<Service>> namespaceSingletonMaps;

code_3.2
客户端保存发布者信息(客户端发送心跳请求,会使用到publishers )

	IpPortBasedClientConcurrentHashMap<Service, InstancePublishInfo> publishers = new ConcurrentHashMap<>(16, 0.75f, 1);
    publishers.put(service, instancePublishInfo)

总结:nacos心跳机制及健康检查有了个初步的了解

仔细看了下NotifyCenter源码,nacos-common.notify包,大概结构如下(发布–订阅模式)
在这里插入图片描述
简单聊聊这个设计模式,通俗来讲就是:“我放个屁股在这里,有瓜踢一下”,或者举个例子
我是一个销售人员,专门卖BYD电动汽车的,A,B,C三个用户找我买比亚迪汉,巧了暂时没有货,然后他们每人给了一个联系方式给我,等哪天有货了,我再去通知他们过来买车。

  • 可以看到,A,B,C三个用户买车的动作受到货源的影响,用户不能一直等下去(解耦)
  • 用户都给了我一个联系方式,等我call他们来买车(我作为发布者,用户作为订阅者,我call他们是一个动作,最终还是他们来买车)
    所以发布订阅者模式需要关注的点:

什么时候建立订阅关系
什么时候触发(发布者什么时候通知订阅者)
订阅者需要执行的动作

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值