SpringBoot服务在服务启动完成前被提前注册到nacos

Rockynacos大约 2 分钟

springboot服务在服务启动完成前提前注册到nacos,gateway拿到服务提供者信息后转发请求导致请求异常

Untitled
Untitled

上图中的例子两个时间相差3秒时间(估计因为我机子当时在做测试,cpu基本满了,导致时间相差比较大)。

版本信息:

nacos版本:2021.0.5.0

springboot版本:2.6.13

gateway中有额外写一个监听器监听nacos事件,如果是NamingEvent,则更新服务缓存。

看代码应该是这里触发了注册:

Untitled
Untitled

提交bug给nacos,回复不是nacos的职责,所以不处理

当然有其他方法也能做到无损发布,比如结合k8s的就绪探针等等。但这样会动底层,所以自己修改了nacos源码,增加了一个就绪探测的功能,就绪后才注册到nacos中

https://github.com/alibaba/nacos/issues/11061open in new window


系统推荐









  • 随机毒鸡汤:只要你想要而只要我有,不管什么,老子都不会给你。