nacos心跳机制重复发送原理

本文探讨nacos注册服务时的心跳机制,通过分析源码指出,尽管使用了ScheduledThreadPoolExecutor的schedule方法,但通过在BeatTask的run方法中循环调用schedule来实现心跳的重复发送。文章提出疑问:为何nacos不直接使用scheduleAtFixedRate或scheduleWithFixedDelay,期待读者分享见解。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在学习nacos源码的时候,正好看到了一个点,和昨天记录的ScheduledThreadPoolExecutor有点关系,所以记录下这个点

nacos在注册服务的时候,会定时发送心跳,在发送心跳的时候,调用的是ScheduledThreadPoolExecutor.schedule()方法,昨天的笔记中,有记录,这个方法其实是只会调用一次的,ScheduledThreadPoolExecutor也提供了两个循环重复定时调用任务的方法,但是nacos没有使用,用的反而是schedule方法,那是如何实现重复发送心跳的呢?循环递归调用。。。

因为nacos所谓的心跳机制,其实就是nacos-client定时的给nacos-server发送请求,告诉server,当前服务是正常的,所以一定是循环重复定时调用的

/**
 * Add beat information.
 * 添加心跳线程,需要注意的是,这里只会发送一次心跳,但是在run方法中,会重复调用schedule方法
 * @param serviceName service name
 * @param beatInfo    beat information
 */
public void addBeatInfo(String serviceName, BeatInfo beatInfo) {
   
   
	NAMING_LOGGER.info("[BEAT] adding beat: {} to beat map.", beatInfo);
	String key = buildKey(serviceName, beatInfo.getIp(), beatInfo.getPort());
	BeatInfo existBeat = null;
	//fix #1733
	if ((existBeat = dom2Beat.remove(key)) != null) {
   
   
		existBeat.setStopped(true);
	}
	dom2Beat.put(key, beatInfo);
	/**
	 * 这个schedule只会发送一次心跳
	 */
	executorService.schedule(
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值