Debug —— 部署微服务中微服务的配置文件及本地注册Nacos没问题但部署到Docker中就注册失败

问题



解决方案

为什么服务在docker中总是自动连的是19375阿???

  • 客户端连 127.0.0.1:19375 根本不是配置写错,而是它"没能从 Nacos 拿到可解析的节点地址",于是硬编码 fallback 到 localhost + 随机高段端口。

首先我是在本地Docker测试部署的,然后Docker中都是最小化的嘛,很多命令都是没有的。因此尽可能用本地可以直接用的命令

用命令直接在宿主机(你的电脑)上访问 Nacos 的接口,看它返回什么地址。

注意这里因为我创建nacos的时候是18375:8848,是本地的18375映射到docker中的8848,所以主机访问nacos要通过访问本地的18375端口

bash 复制代码
curl http://localhost:18375/nacos/v1/core/cluster/nodes

结果

bash 复制代码
{"code":200,"message":null,"data":[{"ip":"d566c5a53d26","port":8848,"state":"UP","extendInfo":{"raftPort":"7848","readyToUpgrade":true,"version":"2.1.0"},"address":"d566c5a53d26:8848","failAccessCnt":0,"abilities":{"remoteAbility":{"supportRemoteConnection":true},"configAbility":{"supportRemoteMetrics":false},"namingAbility":{"supportJraft":true}}}]}

不是 IP,而是随机容器 hostname,业务容器同样解析不到,于是客户端又 fallback 到 127.0.0.1:19375。

bash 复制代码
{"code":200,"message":null,"data":[{"ip":"nacos","port":8848,"state":"UP","extendInfo":{"raftPort":"7848","readyToUpgrade":true,"version":"2.1.0"},"address":"nacos:8848","failAccessCnt":0,"abilities":{"remoteAbility":{"supportRemoteConnection":true},"configAbility":{"supportRemoteMetrics":false},"namingAbility":{"supportJraft":true}}}]}

然而报错仍然一模一样

  • 现在不是网络问题,而是客户端版本太旧,根本不认识 server-grpc-addr,只能去"猜"节点列表里的地址------一旦拿到 随机 hostname(bcbc5175e64d)或 127.0.0.1 就 fallback 到 127.0.0.1:19375,所以永远注册不上。


虽然仍旧报错,但是终于不是访问19375端口了!!!!!!!

  • 注意:修改容器内容后记得删除原来的镜像然后重新拉取镜像,不要直接重启,用的镜像还是原来的!!!



成功本地部署

相关推荐
EMA5 小时前
Docker虚拟化失败解决方案
架构
李斯维6 小时前
从历史的角度看 Android 软件架构
android·架构·android jetpack
JouYY8 小时前
聊一下多 Agent 编排架构的应用实践
架构·llm·agent
Sunia9 小时前
《AgentX 专栏》10-生产部署:3台2C4G云服务器把企业级Agent真正跑起来的完整方案
java·架构
ZhengEnCi1 天前
Q01-高并发点赞系统架构设计
架构
笨鸟飞不快2 天前
从 MVC 到 DDD:一次真实的渐进式迁移实录
后端·架构
这个DBA有点耶2 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构
锋行天下2 天前
我试图优化 Vite 的拆包,结果首屏慢了 10 倍
前端·vue.js·架构
小鼻子的猫3 天前
独立开发 30 天:2.5 万行代码,23 个 Bug,5 次重构——一个 AI 社区的诞生
架构