我是 docker 新手,我一直在将我的所有应用程序 docker 化到一个服务器中。到目前为止,一切都很好并且工作正常。但是,我不明白一件事。我对所有东西都使用了 docker-compose(我还没有为我的项目创建 dockerfile),并且 docker ports
-compose 中有这个属性。如果我写这样的东西:
ports:
8085:80
它将监听 0.0.0.0:8085,这意味着外部世界可以访问我的服务器。经过一番讨论和google-ing,我发现我可以在我的docker bridge网络中获取一个IP地址并轻松进行端口映射:
ports:
172.17.0.1:8085:80
这只会在 172.17.0.1:8085 上侦听,这很棒,因为它只在内部侦听,而我的 nginx 将流量代理到必要的端口。(例如proxy_pass http://172.17.0.1:8085
)。在对 docker 有了更多了解并了解了它们的工作原理后,我意识到所有这些容器都有自己的 IP 地址,并且端口只暴露给这些地址。例如,我的一个“网络”容器的 IPv4 地址为 172.17.0.10,并且端口 80 已公开。如果我docker inspect
在其中一个容器上执行此操作,我将看到容器的 IP 地址。
现在,我想在我的 nginx 中使用这些 IP 地址。而不是proxy_pass http://172.17.0.1:8085
,我想做http://172.17.0.10
。我个人认为这是一个非常优雅的界面,但有一件事让我担心。如果我重新启动机器会发生什么?所有容器将以某种顺序启动。如果我有 5 个 Web 容器并且它们以随机顺序启动,我可以确定这些容器的 IP 相同吗?或者他们会改变吗?我应该总是ports
在 docker-compose 中使用 nginx 使用吗?如果是,我怎样才能为每个容器设置不同的 IP,而不是使用相同 IP 的不同端口?如果我创建另一个 docker 网络接口(假设在子网 172.17.1.0 中),并将该接口的不同 IP 分配给暴露的“公共”端口,是否可以?我的意思是基本上172.17.1.1:80:80
在一个容器中使用,172.17.1.2:80:80
在另一个等