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

相关推荐
Yupureki2 小时前
《Linux网络编程》2.Socket编程(UDP/TCP)
linux·服务器·c语言·网络·c++·tcp/ip·udp
竹之却2 小时前
【Linux】内网穿透原理
linux·服务器·网络·frp·内网穿透·p2p·xtcp
薛定谔的码*2 小时前
双机热备份MSTP+VRRP+负载均衡
运维·网络·负载均衡
努力搬砖的鱼2 小时前
校园网SSH连接超时故障深度排查:从TCP重传到物理链路MTU限制
网络·tcp/ip·ssh
HalvmånEver2 小时前
Linux:基于TCP Socket的在线翻译
linux·运维·服务器·网络·学习·tcp/ip
[shenhonglei]2 小时前
PolarDB-X Docker 部署与登录实战:从拉取镜像到客户端连接
运维·docker·容器
A.A呐2 小时前
【Linux第二十四章】IP协议
linux·网络
志栋智能2 小时前
超自动化巡检:构筑业务连续性的第一道智能防线
大数据·运维·网络·人工智能·自动化
ai_xiaogui2 小时前
PanelAI 最新进展:AI算力集群一键部署ComfyUI & Stable Diffusion,多节点Docker管理面板从原型到真实数据全解析
人工智能·docker·stable diffusion·ai算力集群管理·ai私有化部署工具·ai容器管理与算力调度实战·多节点docker服务器面板