想象一下一个不平凡的docker compose应用程序,其中Nginx位于Web应用程序的前面,并且有几个链接的数据存储区:
web:
build: my-django-app
volumes:
- .:/code
ports:
- "8000:8000"
links:
- redis
- MysqL
- mongodb
Nginx:
image: Nginx
links:
- web
redis:
image: redis
expose:
- "6379"
MysqL:
image: MysqL
volumes:
- /var/lib/MysqL
environment:
- MysqL_ALLOW_EMPTY_PASSWORD=yes
- MysqL_DATABASE=myproject
mongodb:
image: mongo
数据库非常容易配置(目前),容器公开了很好的环境变量来控制它们(请参见MysqL容器),但是Nginx是什么?我们需要为此模板一个虚拟主机文件,对吗?
我不想投射自己的映像,这需要针对每个更改的配置(从不同开发人员的设置)进行重新构建,以进行测试,以及进行分阶段和生产.如果我们想通过轻巧的方式通过配置选项进行A / B测试,该怎么办?
这里需要一些集中化的配置管理,也许是由docker-compose控制的可以将配置文件写到共享卷的东西?
随着添加新服务,这将变得更加重要(想象一个微服务云,而不是像本例中那样的整体Web应用程序)
在docker-compose项目中管理配置的正确方法是什么?
最佳答案