记一次服务间调用失败的bug

1. 服务环境描述

1.所有服务都注册到Consul上,服务间调用采用的是服务名;

2.所有服务用docker容器化部署,用docker swarm管理服务集群;

3.docker compose编排文件里的所有服务的端口均未映射出来,即没有加 ports: -8080:8080 这样的配置项;

2. 增加A服务的端口映射

由于需求需要,我让工程把服务器上的 A 服务的端口映射出来,

于是工程在docker-compose.yml 中A服务处新增了 ports: -8099:8099 这样的配置项。

3. 问题出现

B服务的日志内报无法调通 A 服务的异常

4. 排查

于是我进入B服务的容器内,用curl命令发请求,发现确实请求不通A服务,但是把A服务的serviceName1 改成 serviceName2:8099 可以请求通;

【注:serviceName1 是A服务在consul中的服务名,serviceName2:8099 是A服务在docker-compose编排里的服务名】

5. 猜测

由于第二步修改A服务的端口映射,到问题出现,中间隔了好几天,所以一开始并没想到是由于A服务的端口映射导致的这个问题,后来才想到可能跟这个有关系;

于是把docker-compose.yml 中A服务的 ports: -8099:8099 配置项注释了,重启服务,发现B服务就能正常通过serviceName1 调用A服务了。

6. 原因分析&解决

主机有多个网络(可通过docker network ls 查看),注册到consul时错误的网络会导致服务间无法调用,因此需要指定一下优先使用哪个网络。

需要在A服务的bootstrap.yml的配置文件中新增如下配置项:

(因为docker编排中设置的网络名称就是XXX_NET)

|-----------|--------------------------------------------------------------------------------|
| 1 2 3 4 5 | spring: ``cloud: ``inetutils: ``preferred-networks: ``- $XXX_NET |

参考:https://www.cnblogs.com/noidler/p/15019986.html

相关推荐
撸码到无法自拔1 小时前
docker常见命令
java·spring cloud·docker·容器·eureka
hi,编程哥5 小时前
Docker、ECS 与 K8s 网段冲突:解决跨服务通信中的路由问题
docker·容器·kubernetes
How_doyou_do6 小时前
项目全栈实战-基于智能体、工作流、API模块化Docker集成的创业分析平台
运维·docker·容器
xbd_zc10 小时前
【Jenkins简单自动化部署案例:基于Docker和Harbor的自动化部署流程记录】
docker·自动化·jenkins·harbor
我的璨宝宝啊11 小时前
linux小主机搭建自己的nas(三)docker安装nextcloud
linux·运维·docker
大米☋11 小时前
GitLab搭建与使用(SSH和Docker)两种方式
docker·ssh·gitlab
污斑兔13 小时前
在Mac环境下搭建Docker环境的全攻略
docker
modest —YBW13 小时前
Ollama+OpenWebUI+docker完整版部署,附带软件下载链接,配置+中文汉化+docker源,适合内网部署,可以局域网使用
人工智能·windows·docker·语言模型·llama
心动啊12114 小时前
docker使用过程中遇到概念问题
运维·docker·容器
Penguido15 小时前
基于 Nexus 在 Dockerfile 配置 yum, conda, pip 仓库的方法和参考
linux·docker·centos·conda·pip