暴露多个本地运行的 docker 容器

Posted

技术标签:

【中文标题】暴露多个本地运行的 docker 容器【英文标题】:Exposing multiple docker containers running locally 【发布时间】:2021-06-26 09:51:52 【问题描述】:

我正在创建一个 SaaS 项目,让最终用户可以将仪表板作为 Docker 容器的 Web 应用程序运行和访问,这意味着每个用户都有自己的仪表板,它是一个正在运行的 Docker 容器,我希望他们能够使用我的域 (HTTP) 访问他们的服务器/容器,如下所示:user1:subdomain.mydomain.com/user1app,user2:subdomain.mydomain.com/user1app 等。

目前,我正在使用 LocalTunnel,但它不稳定,需要我为每个用户使用 1 个子域,例如:user1.mydomain.com、user2.mydomain.com 等。 但是如果我们扩大规模并获得更多用户呢?我需要一种动态和自动的方式来创建用户自定义 URL 链接以公开他们正在运行的 docker 容器并授予他们访问权限,例如 subdomain.mydomain.com/user123、subdomain.mydomain.com/user456 等。

我尝试使用 ngrok,但是它在很多方面都受到限制,例如40 个请求/分钟的限制,而且不是免费的。 谢谢

【问题讨论】:

澄清一下,40 个连接/分钟的限制仅适用于免费的 ngrok 帐户。付费帐户确实有更高的限制。 【参考方案1】:

我建议使用 docker 运行 nginx-revsere-proxy,您可以只使用一个 ip 托管任意数量的 webapp。

https://github.com/nginx-proxy/nginx-proxy

您可以在此处添加每个主机配置,甚至更改默认配置。因此,您可以为每个仪表板编写配置或使用变量和 bashscript 来创建主机配置

【讨论】:

感谢您的回答!我想让它动态配置,加上一些服务器在本地运行,我想通过隧道公开它们。 是的,这个反向代理正在寻找新的容器,然后自动设置。一切都是通过环境变量控制的,你也可以在那里设置它,它只能在内部访问。

以上是关于暴露多个本地运行的 docker 容器的主要内容,如果未能解决你的问题,请参考以下文章

Docker容器 暴露多个端口

运行 apache 的 Docker 容器总是暴露端口 80

谷歌云防火墙暴露端口 Docker

似乎无法将 docker 容器端口暴露给主机

无法通过容器的 ip 和通过 http 暴露的端口访问 Docker 容器中的 Web 应用程序

Gitlab CI runner 无法暴露嵌套 Docker 容器的端口