《8076 能通 9003 却超时?一次 Docker 容器跨网段排障小记》

标题:


01 现象

同一容器内:

  • curl 192.168.100.8:8076 立即返回 HTTP/1.1 404 ------ 网络通
  • curl 192.168.100.8:9003 一直卡在 * Trying 192.168.100.8:9003... 直到超时 ------ 网络不通

宿主机(192.168.100.8)本地执行 curl localhost:9003 正常,所以服务确定在跑。


02 快速定位思路

  1. 能 ping 能解析 ≠ 能建 TCP

    容器里 pinggetent hosts 都 OK,排除 DNS 与三层路由大问题。

  2. 抓包看 SYN 有没有回包
    tcpdump -i any host 192.168.100.8 and port 9003

    只看到 SYN,没有 SYN-ACK → 包被目标主机丢弃。

  3. 端口差异对比

    8076 通、9003 不通,说明网络链路(Docker 网桥 → 宿主机转发 → 物理交换机)没问题,问题只出在 9003 端口本身


03 根因

登录 192.168.100.8 查看监听与防火墙:

bash 复制代码
ss -ltnp | grep 9003
# 返回 0.0.0.0:9003  已监听 → 进程正常
sudo iptables -nvL INPUT | grep 9003
# 空空如也 → 没放行

INPUT 链默认 DROP 掉了 9003 的入站流量


04 一键修复

bash 复制代码
# 在目标主机(192.168.100.8)执行
sudo iptables -I INPUT -p tcp --dport 9003 -j ACCEPT
# 永久生效
sudo apt install iptables-persistent -y
sudo netfilter-persistent save

回容器再测:

bash 复制代码
curl -v http://192.168.100.8:9003/
# < HTTP/1.1 200 OK

RustFS 日志也不再出现 Connect timeout on endpoint URL: http://192.168.100.8:9003/...


05 小结

  • 容器侧超时 80% 是四层被拦,不是 Docker 本身问题。
  • "能通 A 端口,不能通 B 端口" 是最直观的拆分法:网络层已通,就看监听地址 + 本地防火墙
  • 记住三步:
    1. ss -ltnp 确认监听范围
    2. iptables -nvL 看 DROP 计数
    3. 加一条 -I INPUT ... ACCEPT 验证

把这条命令收藏起来,下次 30 秒就能判定位似问题。

相关推荐
Cosolar2 小时前
LlamaIndex索引类型全解析:原理与实战指南
运维·服务器
方便面不加香菜4 小时前
Linux--基础IO(一)
linux·运维·服务器
鼎讯信通7 小时前
风电光缆运维提质增效:G-4000A 光缆故障追踪仪破解风场巡检难题
运维·网络·数据库
三十..7 小时前
MySQL 从入门到高可用架构实战精要
运维·数据库·mysql
杨浦老苏7 小时前
开源多用户图书追踪系统LibrisLog
docker·群晖·收藏管理
跨境数据猎手8 小时前
大数据在电商行业的应用
大数据·运维·爬虫
linyanRPA8 小时前
影刀RPA店群自动化实战:多店铺活动自动报名与促销管理架构设计
运维·自动化·办公自动化·rpa·python脚本·爬虫自动化·店群自动化
会Tk矩阵群控的小木9 小时前
安卓群控系统对于游戏工作室实战教程
android·运维·游戏·adb·开源软件·个人开发
赵渝强老师9 小时前
【赵渝强老师】Kubernetes(K8s)中的金丝雀升级
linux·docker·云原生·容器·kubernetes
鹤落晴春9 小时前
【K8s】配置存储卷
云原生·容器·kubernetes