Docker 无法从远程机器访问容器
Docker container unreachable from remote machine
我使用 docker
和 docker-compose
进行部署,运行 我的 java 应用程序 运行 在端口 5555 上运行。
我运行它作为docker-compose -f docker-compose.yml up -d
但是如果我在 docker 容器是 运行nig 的服务器外部执行 运行 telnet 命令,我会收到 Connection refused
消息。如果运行它在服务器里面一切正常。
所以检查了这些东西:
$: docker-撰写 ps
$: ufw 状态
Status: active
To Action From
-- ------ ----
OpenSSH ALLOW Anywhere
5555/tcp ALLOW Anywhere
5432 ALLOW Anywhere
OpenSSH (v6) ALLOW Anywhere (v6)
5555/tcp (v6) ALLOW Anywhere (v6)
5432 (v6) ALLOW Anywhere (v6)
docker-compose.yml
version: '3'
services:
db:
container_name: db
image: postgres
restart: always
ports:
- 5432:5432
auth:
container_name: auth
image: registryimg
restart: always
stdin_open: true
tty: true
ports:
- 5555:5555
Dockerfile
FROM openjdk:8-jre
ADD target/auth.jar app.jar
EXPOSE 5555
ENTRYPOINT ["java", "-Djava.security.egd=file:/dev/./urandom", "-jar", "app.jar"]
更新 1
从我容器的 docker 日志中,我发现应用程序正确绑定到所需的端口:
2019-01-18 10:18:11.481 DEBUG 1 --- [ntLoopGroup-2-1] io.netty.handler.logging.LoggingHandler : [id: 0xaf27337e] REGISTERED
2019-01-18 10:18:11.485 DEBUG 1 --- [ntLoopGroup-2-1] io.netty.handler.logging.LoggingHandler : [id: 0xaf27337e] BIND: localhost/127.0.0.1:5555
2019-01-18 10:18:11.489 DEBUG 1 --- [ntLoopGroup-2-1] io.netty.handler.logging.LoggingHandler : [id: 0xaf27337e, L:/127.0.0.1:5555] ACTIVE
更新 2
从我的家用计算机我 运行 telnet 命令 telnet myhost 5555
我得到一个错误:
Trying myhost...
telnet: Unable to connect to remote host: Connection refused
完成后我查看我的容器日志,它们是空的(netty 没有注册任何连接)。
否则我想指出的是,如果我 telnet 另一个装有 potgresql 的容器 - 一切正常。
好吧,回答是想想你绑定的是什么主机。
在我的例子中,netty 服务器是这样绑定的:
BIND: localhost/127.0.0.1:5555
我已将其更改为:
BIND: 0.0.0.0/0.0.0.0:5555
它就像一个魅力!
我使用 docker
和 docker-compose
进行部署,运行 我的 java 应用程序 运行 在端口 5555 上运行。
我运行它作为docker-compose -f docker-compose.yml up -d
但是如果我在 docker 容器是 运行nig 的服务器外部执行 运行 telnet 命令,我会收到 Connection refused
消息。如果运行它在服务器里面一切正常。
所以检查了这些东西:
$: docker-撰写 ps
$: ufw 状态
Status: active
To Action From
-- ------ ----
OpenSSH ALLOW Anywhere
5555/tcp ALLOW Anywhere
5432 ALLOW Anywhere
OpenSSH (v6) ALLOW Anywhere (v6)
5555/tcp (v6) ALLOW Anywhere (v6)
5432 (v6) ALLOW Anywhere (v6)
docker-compose.yml
version: '3'
services:
db:
container_name: db
image: postgres
restart: always
ports:
- 5432:5432
auth:
container_name: auth
image: registryimg
restart: always
stdin_open: true
tty: true
ports:
- 5555:5555
Dockerfile
FROM openjdk:8-jre
ADD target/auth.jar app.jar
EXPOSE 5555
ENTRYPOINT ["java", "-Djava.security.egd=file:/dev/./urandom", "-jar", "app.jar"]
更新 1
从我容器的 docker 日志中,我发现应用程序正确绑定到所需的端口:
2019-01-18 10:18:11.481 DEBUG 1 --- [ntLoopGroup-2-1] io.netty.handler.logging.LoggingHandler : [id: 0xaf27337e] REGISTERED
2019-01-18 10:18:11.485 DEBUG 1 --- [ntLoopGroup-2-1] io.netty.handler.logging.LoggingHandler : [id: 0xaf27337e] BIND: localhost/127.0.0.1:5555
2019-01-18 10:18:11.489 DEBUG 1 --- [ntLoopGroup-2-1] io.netty.handler.logging.LoggingHandler : [id: 0xaf27337e, L:/127.0.0.1:5555] ACTIVE
更新 2
从我的家用计算机我 运行 telnet 命令 telnet myhost 5555
我得到一个错误:
Trying myhost...
telnet: Unable to connect to remote host: Connection refused
完成后我查看我的容器日志,它们是空的(netty 没有注册任何连接)。
否则我想指出的是,如果我 telnet 另一个装有 potgresql 的容器 - 一切正常。
好吧,回答是想想你绑定的是什么主机。
在我的例子中,netty 服务器是这样绑定的:
BIND: localhost/127.0.0.1:5555
我已将其更改为:
BIND: 0.0.0.0/0.0.0.0:5555
它就像一个魅力!