java – 无法从主机访问Docker端口

前端之家收集整理的这篇文章主要介绍了java – 无法从主机访问Docker端口前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我有一个新的Spring Boot应用程序,我刚刚完成并尝试将其部署到Docker.在容器内部,应用程序正常工作.它使用端口9000进行面向用户的请求,使用9100进行健康检查等管理任务.当我启动docker实例并尝试访问端口9000时,我收到以下错误

  1. curl: (56) Recv failure: Connection reset by peer

经过大量的实验(通过curl),我确认了几个不同的配置,应用程序在容器内运行良好,但是当我尝试将端口映射到主机时它没有连接.我尝试使用以下命令启动它.它们都不允许我从主机访问端口.

  1. docker run -P=true my-app
  2. docker run -p 9000:9000 my-app

解决方法

works使用–net host option的唯一方法,但这不允许我在该主机上运行多个容器.

  1. docker run -d --net=host my-app

端口和暴露实验

我使用了各种版本的Dockerfile,暴露了不同的端口,如9000和9100或只有9000.这些都没有帮助.这是我的最新版本:

  1. FROM ubuntu
  2. MAINTAINER redacted
  3. RUN apt-get update
  4. RUN apt-get install openjdk-7-jre-headless -y
  5. RUN mkdir -p /opt/app
  6. WORKDIR /opt/app
  7. ADD ./target/oauth-authentication-1.0.0.jar /opt/app/service.jar
  8. ADD config.properties /opt/app/config.properties
  9. EXPOSE 9000
  10. ENTRYPOINT java -Dext.properties.dir=/opt/app -jar /opt/app/service.jar

Hello World有效

为了确保我可以运行Spring Boot应用程序,我尝试了Simplest-Spring-Boot-MVC-HelloWorld并且它工作正常.

Netstat结果

我使用netstat从主机和容器进行端口扫描:

来自主持人

  1. root@my-docker-host:~# nmap 172.17.0.71 -p9000-9200
  2. Starting Nmap 6.40 ( http://nmap.org ) at 2014-11-14 19:19 UTC Nmap
  3. scan report for my-docker-host (172.17.0.71)
  4. Host is up (0.0000090s latency).
  5. Not shown: 200 closed ports
  6. PORT STATE SERVICE
  7. 9100/tcp open jetdirect
  8. MAC Address: F2:1A:ED:F4:07:7A (Unknown)
  9. Nmap done: 1 IP address (1 host up) scanned in 1.48 seconds

从容器

  1. root@80cf20c0c1fa:/opt/app# nmap 127.0.0.1 -p9000-9200
  2. Starting Nmap 6.40 ( http://nmap.org ) at 2014-11-14 19:20 UTC
  3. Nmap scan report for localhost (127.0.0.1)
  4. Host is up (0.0000070s latency).
  5. Not shown: 199 closed ports
  6. PORT STATE SERVICE
  7. 9000/tcp open cslistener
  8. 9100/tcp open jetdirect
  9. Nmap done: 1 IP address (1 host up) scanned in 2.25 seconds

容器正在使用Ubuntu
我复制过的主机是Centos和Ubuntu.

This SO question看起来很相似,但很少有细节,没有答案,所以我想我会尝试更多地记录我的情景.

最佳答案
我遇到了类似的问题,其中将主机IP地址指定为“127.0.0.1”将无法正确地将端口转发到主机.

将Web服务器的IP设置为“0.0.0.0”可以解决问题

例如 – 对于我的Node应用程序 – 以下内容不起作用

  1. app.listen(3000,'127.0.0.1')

以下哪项有效:

  1. app.listen(3000,'0.0.0.0')

我猜这意味着默认情况下,docker正在暴露0.0.0.0:containerPort – >当地港口

猜你在找的Docker相关文章