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端口了!!!!!!!

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



成功本地部署

相关推荐
齐鲁大虾16 分钟前
Linux下用什么编程语言方便开发B/S架构程序
linux·运维·架构
Volunteer Technology24 分钟前
MinIo介绍和使用
架构
三块钱079433 分钟前
群晖docker部署Mattermost,对接openclaw
运维·docker·容器
h7ml1 小时前
淘宝返利软件的跨端同步架构:Java RESTful API+GraphQL满足Web/APP/小程序的多端数据需求
java·架构·restful
茂桑1 小时前
DDD领域驱动设计-基础设施层
设计模式·架构
大转转FE1 小时前
转转前端周刊第185期: 深度解析Moltbot 底层架构
架构
潆润千川科技1 小时前
技术视角下的中老年垂直社交应用:架构考量与体验平衡
架构·聊天小程序
yuezhilangniao1 小时前
从对话大脑到万能助手:企业级AI助理五层AI架构实战指南-AI开发架构AI体系理性分层篇
人工智能·架构
JZC_xiaozhong2 小时前
多系统权限标准不统一?企业如何实现跨平台统一权限管控
java·大数据·微服务·数据集成与应用集成·iam系统·权限治理·统一权限管理
苦逼IT运维3 小时前
从 0 到 1 理解 Kubernetes:一次“破坏式”学习实践(一)
linux·学习·docker·容器·kubernetes