亲测解决,nacos下线失败!

场景重现

当多个开发者共同投入一个项目的时候,通常会出现一个项目同时启动,调用接口调试工具共同测试的接口开发情况的情形;为了保证测试环境的稳定性,我们一般不通过页面进行调试,这时我们会采用在nacos服务中,将测试应用下线的动作;如下图,我们需要将B + C服务下线。

亲测解决,nacos下线失败!_第1张图片

问题浮现

当点击“下线”按钮的时候,无法正常下线,出现下面问题。

亲测解决,nacos下线失败!_第2张图片

caused: errCode: 500, errMsg: 
do metadata operation failed ;caused: com.alibaba.nacos.consistency.exception.ConsistencyException: 
The Raft Group [naming_instance_metadata] did not find the Leader node;caused: The Raft Group [naming_instance_metadata] did not find the Leader node;
//错误消息表示Raft Group [naming_instance_metadata] 没有找到Leader节点。这可能是由网络问题、节点故障或者配置错误导致的。

这是因为:当我们自己的服务器 IP 改变时(网络环境不稳定,如WIFI或者IP地址变化),导致 raft 记录的集群地址失效。我的问题原因是网络的变化,我在nacos启动过程中,IP地址有变化;①采用删除nacos安装目录下data下的protocol文件夹;②重启nacos服务的方法即可解决。

亲测解决,nacos下线失败!_第3张图片

番外一:Linux如何找到/data/protocol文件夹

备注:下面的内容是前提是,使用docker启动的nacos

1.查看容器名称

docker ps

亲测解决,nacos下线失败!_第4张图片

2.进入容器

// 进入容器
docker exec -it nacos bash

// 如果你进来的目录不对,不要着急,进入/home/nacos目录下即可
cd /home/nacos

// 进入data目录,重复下面步骤,删除目标文件夹即可
rm -rf protocol/

亲测解决,nacos下线失败!_第5张图片

番外二:Linux如何删除protocl文件夹

// 进入data目录
cd /data
// 循环删除protocol目录
rm -rf protocol/
nacos的raft协议

nacos介绍

Nacos是一个用于动态服务发现、配置管理和服务管理的开源项目。

Nacos集群不仅支持AP模式(分区可用性),也支持CP模式(分区一致性)。对于临时数据的同步,采用的是AP模式,对于持久性的数据,采用的CP模式,使用raft协议实现。

raft协议是什么
在Nacos的架构中,使用了Raft协议来实现多节点之间的一致性。raft协议是一种分布式一致性协议。raft协议保证集群中节点的数据的一致性,是一种强一致性协议。

有问题私信我。欢迎关注微信公众号:小红的成长日记,一起学Java!

你可能感兴趣的:(java)