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

Exo*_*imp 8 load-balancing nginx docker docker-compose docker-container

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

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

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

And*_*inn 9

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

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

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