本地 Docker 容器的“网络端点状态异常”,如何快速修复

故障总结

这次不是业务代码故障,核心是本地 Docker 容器的"网络端点状态异常"。

具体表现:

  • aigc-php-local 容器配置里写着加入网络 docker-compose-local-aigc_host
  • 但实际 docker inspect 看到 NetworkSettings.Networks 是空的 {},说明容器对象没有真正挂到 Docker 网络
  • 因此 PHP 启动时解析不到 redis,在 QueueHelper.php 连接 Redis 直接报错退出
  • aigc-nginx-localaigc-node-local 也出现了同类问题,所以 nginx 又解析不到 aigc-php-local / aigc-node-local

本质上是:

  • 容器"看起来存在"
  • docker compose ps 里也可能显示正常或重启中
  • 但容器实际没有拿到 compose 网络的 DNS 能力,导致服务名解析失败

这次看到的直接报错

  • PHP:
    RedisException: php_network_getaddresses: getaddrinfo failed
  • Nginx:
    host not found in upstream "aigc-php-local"
    host not found in upstream "aigc-node-local"

快速判断方法

先看容器状态:

powershell 复制代码
docker compose -f D:\phpstudy_pro\WWW\zhilin\aigc\docker-compose-local\docker-compose.yaml ps

再看失败日志:

powershell 复制代码
docker logs --tail 100 aigc-php-local
docker logs --tail 100 aigc-nginx-local
docker logs --tail 100 aigc-node-local

再看是不是网络端点丢了:

powershell 复制代码
docker inspect --format '{{json .NetworkSettings.Networks}}' aigc-php-local
docker inspect --format '{{json .NetworkSettings.Networks}}' aigc-nginx-local
docker inspect --format '{{json .NetworkSettings.Networks}}' aigc-node-local

如果输出是 {},基本就可以确定是这类问题。

下次怎么快速修复

优先用最小修复,直接强制重建异常容器:

powershell 复制代码
docker compose -f D:\phpstudy_pro\WWW\zhilin\aigc\docker-compose-local\docker-compose.yaml up -d --force-recreate php
docker compose -f D:\phpstudy_pro\WWW\zhilin\aigc\docker-compose-local\docker-compose.yaml up -d --force-recreate node
docker compose -f D:\phpstudy_pro\WWW\zhilin\aigc\docker-compose-local\docker-compose.yaml up -d --force-recreate nginx

如果你想一步到位,也可以:

powershell 复制代码
docker compose -f D:\phpstudy_pro\WWW\zhilin\aigc\docker-compose-local\docker-compose.yaml up -d --force-recreate

推荐的排查顺序

  1. 先看 php 日志
  2. 如果报 redis/mysql/host not found,立刻检查 NetworkSettings.Networks
  3. 如果是 {},不要先改代码,先 --force-recreate
  4. 然后再看 nginx 是否还报 upstream 解析失败
  5. 最后用接口实测一次

一套最快恢复命令

powershell 复制代码
docker compose -f D:\phpstudy_pro\WWW\zhilin\aigc\docker-compose-local\docker-compose.yaml up -d --force-recreate php node nginx
docker compose -f D:\phpstudy_pro\WWW\zhilin\aigc\docker-compose-local\docker-compose.yaml ps
docker logs --tail 50 aigc-php-local
docker logs --tail 50 aigc-nginx-local

怎么确认已经恢复

看这几个点:

  • docker compose psphp / node / nginx 都是 Up
  • docker inspect --format '{``{json .NetworkSettings.Networks}}' 容器名 不再是 `{}``
  • php 日志里没有 getaddrinfo failed
  • nginx 日志里没有 host not found in upstream
  • 本地接口能返回 HTTP 200 或至少返回业务层错误,而不是容器层错误

一句话记忆

下次如果看到:

  • getaddrinfo failed
  • host not found in upstream

先别怀疑代码,先查容器是不是"名义上在网络里,实际上没挂上网络端点";如果是,直接 docker compose up -d --force-recreate 重建对应容器。

相关推荐
不会写DN5 小时前
其实跨域问题是后端来解决的? CORS
服务器·网络·面试·go
Harvy_没救了5 小时前
【网络架构】Keepalived + LVS(DR) + MariaDB 双主备实践
网络·架构·lvs
大鹏说大话10 小时前
SSL证书自动化的未来:ACME协议与Let’s Encrypt实践
网络·安全
被摘下的星星11 小时前
网际协议(IP协议)
网络·tcp/ip
爱学习的小囧12 小时前
ESXi VMkernel 端口 MTU 最佳设置详解
运维·服务器·网络·php·虚拟化
eRTE XFUN13 小时前
docker 安装 mysql
mysql·adb·docker
eEKI DAND14 小时前
对Docker部署的MySQL中的数据进行备份恢复
mysql·docker·容器
东北甜妹14 小时前
Docker 瘦身
阿里云·docker·eureka
TechubNews15 小时前
Base 发布首个独立 OP Stack 框架的网络升级 Azul,将是 L2 自主迭代的开端?
大数据·网络·人工智能·区块链·能源
旷世奇才李先生16 小时前
Docker实战:容器化部署与Docker Compose集群管理(附企业级案例)
spring cloud·docker·eureka