首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >暴露在docker容器内运行的SSH隧道的端口

暴露在docker容器内运行的SSH隧道的端口
EN

Stack Overflow用户
提问于 2020-07-08 18:59:15
回答 1查看 110关注 0票数 0

在一个docker容器中,我在一个交互式shell中创建了以下隧道:

代码语言:javascript
复制
ssh -4 root@remotehost.com -L 8443:127.0.0.1:80

在同一个容器的另一个shell中,我可以成功地运行以下命令:

代码语言:javascript
复制
curl http://localhost:8443

服务器(remotehost.com)会使用HTML语言内容进行响应。

(注意:我现在使用纯HTTP,以使其更容易调试。最后,我需要使用HTTPS,这就是为什么我选择本地端口为8443。)

这个docker容器确实公开了它的端口8443:

代码语言:javascript
复制
# docker port be68e57bc3e0
8443/tcp -> 0.0.0.0:8443

但是,当我尝试从主机连接到该端口时,我得到了以下信息:

代码语言:javascript
复制
# curl --verbose http://localhost:8443
*   Trying ::1...
* TCP_NODELAY set
* Connected to localhost (::1) port 8443 (#0)
> GET / HTTP/1.1
> Host: localhost:8443
> User-Agent: curl/7.64.1
> Accept: */*
> 
* Empty reply from server
* Connection #0 to host localhost left intact
curl: (52) Empty reply from server
* Closing connection 0

我迷路了。为什么它的行为与从容器内部连接时的行为不完全相同?我对SSH隧道有什么误解吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-09-18 19:18:31

解决方案是将-g标志添加到创建隧道的ssh行。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62793281

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档