docker

关注公众号 jb51net

关闭
首页 > 网站技巧 > 服务器 > 云和虚拟化 > docker > Docker部署服务端口无法访问

Docker部署服务端口无法访问的排查与解决方法

作者:Knight_AL

在使用 Docker 部署 Grafana 的过程中,我遇到了一个比较常见的问题:容器已经启动成功,宿主机本地能访问 Grafana 的 3000 端口,但在局域网中却无法访问,本文就为大家详细介绍了排查与解决方法,需要的朋友可以参考下

引言

在使用 Docker 部署 Grafana 的过程中,我遇到了一个比较常见的问题:容器已经启动成功,宿主机本地能访问 Grafana 的 3000 端口,但在局域网中却无法访问

问题复现

启动命令如下:

docker run -d \
  --name=grafana \
  -p 3000:3000 \
  --restart always \
  grafana/grafana:9.5.21

在宿主机上 访问:

curl http://127.0.0.1:3000/login

可以正常返回 HTML 页面。

在局域网其他机器浏览器访问:

http://192.168.121.140:3000

却始终打不开。

当我使用 --network host 启动时,外部访问就完全正常。

初步排查

确认容器端口映射

docker ps | grep grafana

输出:

0.0.0.0:3000->3000/tcp

映射配置没问题。

确认进程监听端口

ss -tulnp | grep 3000

显示 docker-proxy 正常监听:

防火墙与 SELinux

根因分析

查阅资料后发现,问题可能出在 内核 IP 转发功能未开启
当使用 -p 进行端口映射时,Docker 需要依赖内核的转发功能(NAT 表规则)来把外部请求转发到容器内部。如果 net.ipv4.ip_forward 关闭,即使映射正常,也无法从外部访问。

解决方案

检查 IP 转发状态

sysctl net.ipv4.ip_forward

如果输出是 0,说明转发被关闭。

开启 IP 转发

编辑配置文件:

vi /etc/sysctl.conf

添加或修改:

net.ipv4.ip_forward=1

让配置生效:

sysctl -p

重启 Docker 服务

systemctl restart docker

重新启动容器

docker restart grafana

验证结果

此时在局域网其他机器上 访问:

http://192.168.121.140:3000

Grafana 登录页面可以正常打开。

总结

到此这篇关于Docker部署服务端口无法访问的排查与解决方法的文章就介绍到这了,更多相关Docker部署服务端口无法访问内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文