本地 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 重建对应容器。

相关推荐
淼淼爱喝水3 分钟前
DVWA 文件上传漏洞实验%00 截断实验与.htaccess 文件攻击实验
网络·安全·靶场
omenkk710 分钟前
网络IO模型-从BIO到IO多路复用
服务器·网络
xhbh66614 分钟前
内网端口映射外网完全教程:路由器端口转发配置+内网穿透工具实战
服务器·网络·智能路由器·端口映射·映射
x***r15116 分钟前
Wireshark 4.4.2 Intel 64.dmg Mac 安装教程|附抓包权限设置
网络
广州灵眸科技有限公司16 分钟前
瑞芯微(EASY EAI)RV1126B 模型部署API说明
linux·开发语言·网络·人工智能·深度学习·算法·yolo
susu108301891121 分钟前
docker启动PostgreSQL + TimescaleDB 时序数据库
docker·postgresql·时序数据库
9命怪猫21 分钟前
公司内部网络计费参考
网络
柿柿快乐28 分钟前
用户认证系统实现文档
linux·服务器·网络·学习·基础教学
皮皮虾123430 分钟前
龙珠激斗多开自动挂机搬砖攻略教程
网络·游戏
普马萨特35 分钟前
Uber H3 空间网格系统深度解析
网络