自动将docker容器附加到nginx负载均衡器的上游配置

时间:2016-04-17 17:04:31

标签: nginx docker load-balancing docker-compose docker-container

我正在运行Docker Compose(v2)并且有一个节点服务(网站)和基于python的api,nginx就位于它们前面。

我想做的一件事是能够通过添加更多容器来扩展服务。如果我提前知道我将拥有多少个容器,我可以使用docker提供的容器的IP引用对nginx上游配置进行硬编码。但问题是我希望上游的nginx配置是动态的,例如如果我添加另一个Docker容器,它只需添加将容器的位置附加到上游块中的IP上游列表。

我的想法是创建一个脚本,当容器发生变化时会自动使用env变量附加上游服务器,但我不确定从哪里开始,找不到好的例子。

1 个答案:

答案 0 :(得分:8)

有几种方法可以实现这一目标。您所指的通常称为服务发现,并且有多种形式。我将描述我之前使用过的两个。

第一个也是最简单的(适用于单个服务器或仅在一个服务器上本地发现容器)是一个使用Docker套接字或API的本地代理。 https://github.com/jwilder/nginx-proxy是受欢迎的版本之一,应该可以在Compose中为可伸缩服务进行原型设计。

另一种方式(更多主机友好但更复杂)将在注册表(例如etcd或Consul)中注册服务,然后动态写出配置。为此,您可以使用注册系统(例如https://github.com/gliderlabs/registrator)来注册容器及其端口。然后,您的代理或应用程序可以使用使用https://github.com/kelseyhightower/confd等模板系统编写的配置文件。