Docker绑定端口后仍无法远程直接访问的解决方法
在docker中拉取镜像后启动,启动脚本如下
启动docker
docker run --name nacos-server \ -p 8848:8848 \ -p 7848:7848 \ -p 9848:9848 \ -p 9849:9849 \ --privileged=true \ --restart=always \ -e JVM_XMS=256m \ -e JVM_XMX=256m \ -e MODE=standalone \ -e PREFER_HOST_MODE=hostname \ -v /mydata/nacos/logs:/home/nacos/logs \ -v /mydata/nacos/conf/application.properties:/home/nacos/conf/application.properties \ -d nacos/nacos-server:v2.4.2
其他主机正常访问到控制台

启动zipkin
docker run -d --name zipkin d7cf93f08bd4 \
-e STORAGE_TYPE=mysql \
-e MYSQL_DB=zipkin \
-e MYSQL_USER=root \
-e MYSQL_PASS=yoostar403 \
-e MYSQL_HOST=mysql \
-e MYSQL_TCP_PORT=3306 \
-e KAFKA_BOOTSTRAP_SERVERS=kafka:9092 \
-e STORAGE_TYPE=elasticsearch \
-e ES_HOSTS=http://elasticsearch:9200 \
-p 9411:9411 \
但是同上面nacos的访问,到9411却无法访问拒绝连接。同时看到镜像的进程如下

应该是一个默认绑定了0.0.0.0允许所有通过宿主机ip访问该端口,zipkin则没有。为此我问了GPT,得到如下回答:
根据您提供的信息,问题可能出在 Zipkin 容器的端口绑定配置上。您可以尝试以下步骤来配置 Zipkin 容器,使其支持其他主机访问:
检查 Zipkin 容器的端口绑定:
- 运行
docker ps命令查看 Zipkin 容器的端口绑定情况。确保 Zipkin 容器的端口绑定正确,包括将端口绑定到主机的 IP 地址上。 - 如果 Zipkin 容器的端口绑定只是绑定到容器自身的 IP 地址(比如
127.0.0.1),那么其他主机无法直接访问该端口。
修改 Zipkin 容器的端口绑定:
- 如果 Zipkin 容器的端口绑定只包含容器的内部 IP 地址,您需要修改端口绑定配置,将端口绑定到主机的 IP 地址上,以便其他主机可以访问。
- 您可以通过修改 Docker 容器启动命令中的
-p选项来实现端口绑定。例如,将端口9410绑定到主机的所有 IP 地址可以这样做:-p 9410:9410。
重新启动 Zipkin 容器:
- 修改端口绑定配置后,您需要重新启动 Zipkin 容器,使新的配置生效。可以使用
docker restart <container_name>命令来重新启动容器。
检查防火墙设置:
- 确保主机上的防火墙允许流量通过 Zipkin 容器使用的端口。如果有防火墙规则限制了流量,您需要相应地调整防火墙设置。
通过以上步骤,您应该能够配置 Zipkin 容器,使其支持其他主机访问。如果问题仍然存在,请提供更多详细信息,以便更好地帮助您解决问题。
看上面最有可能的应该就是第一点了,为此停止运行中的容器并删除,重新启动,在后面多加了指定0.0.0.0绑定端口映射。
docker run -d --name zipkin \
-e STORAGE_TYPE=mysql \
-e MYSQL_DB=zipkin \
-e MYSQL_USER=root \
-e MYSQL_PASS=yoostar403 \
-e MYSQL_HOST=mysql \
-e MYSQL_TCP_PORT=3306 \
-e KAFKA_BOOTSTRAP_SERVERS=kafka:9092 \
-e STORAGE_TYPE=elasticsearch \
-e ES_HOSTS=http://elasticsearch:9200 \
-p 0.0.0.0:9411:9411 \
d7cf93f08bd4
就是上面的 -p 0.0.0.0:9411:9411 \ 至此可以正常访问,至于为什么nacos不需要指定,不应该都会默认指定的吗。
以上就是Docker绑定端口后仍无法远程直接访问的解决方法的详细内容,更多关于Docker无法远程直接访问的资料请关注脚本之家其它相关文章!
相关文章
使用docker-compose实现不停机部署/灰度发布的四种方法
灰度发布是一种软件部署策略,它允许将新版本的部分功能或服务逐步推送给用户,而不是一次性对所有用户进行大规模更新,本文主要给大家介绍了使用docker-compose实现不停机部署/灰度发布的四种方法,需要的朋友可以参考下2024-11-11
使用 Docker 在 Ubuntu 上部署 FTP 服务器
本文详细介绍了如何在Ubuntu系统上通过Docker部署FTP服务器的步骤,包括安装Docker、拉取vsftpd镜像以及运行FTP容器等,通过这些步骤,用户可以在提供的免费云服务器上快速搭建起一个安全高效的FTP服务,适合小型项目或个人使用,感兴趣的朋友跟随小编一起看看吧2024-10-10
Docker安装redis并且设置密码,以及进入容器修改密码方式
这篇文章主要介绍了Docker安装redis并且设置密码,以及进入容器修改密码方式,2024-01-01


最新评论