docker - 我可以避免为蓝绿部署重复我的服务定义吗?
问题描述
我正在研究一种简单的方法来蓝绿部署应用程序后端。我从一开始就为后端写了一个 docker-compose 文件,后来迁移了 compose 文件以支持蓝绿。
我不需要 docker swarm 或类似的东西。我使用蓝绿部署,因为该项目的每个前端版本在发布之前都必须经过审查过程,并且在审查后不允许以任何方式进行更改。因此,无论我为前端版本连接的后端端点如何,只要它进行审查,它就会被修复。因此,我会在每个版本中交替使用后端端点,以便随时进行测试和实时后端。
我的问题是:我可以以某种方式简化这些服务定义,因为它们非常重复吗?本质上,蓝色和绿色服务做同样的事情。我什至可以为两者使用相同的端口,因为我的反向代理关心路由请求。但是我无法弄清楚如何使用不同的名称(蓝色或绿色)启动两次服务,所以我复制了后端服务。
version: '3'
networks:
nw1:
external: false
nw2:
external: true
services:
blue:
entrypoint:
- npm
- run
command:
- "start-backend"
- --
- -s
- ${CLIENT_SECRET}
- -c
- ${CLIENT_ID}
- -o
- ${OWNER_ID}
build: .
expose:
- ${BLUE_PORT}
networks:
- nw1
- nw2
environment:
- PORT=${BLUE_PORT}
- CONFIG=live
depends_on:
- mongodb
green:
entrypoint:
- npm
- run
command:
- "start-backend"
- --
- -s
- ${CLIENT_SECRET}
- -c
- ${CLIENT_ID}
- -o
- ${OWNER_ID}
build: .
expose:
- ${GREEN_PORT}
networks:
- nw1
- nw2
environment:
- PORT=${GREEN_PORT}
- CONFIG=live
depends_on:
- mongodb
mongodb:
image: mongo:3.4
environment:
- MONGO_DATA_DIR=/data/db
- MONGO_LOG_DIR=/dev/null
volumes:
- ./myapplication/data/db:/data/db
command: mongod --smallfiles --logpath=/dev/null # --quiet
networks:
- nw1
解决方案
结合不同的选择。第一个是您可以创建两个完全独立的堆栈,一个用于蓝色,另一个用于绿色。您需要将任何公共服务移到第三个公共堆栈中,并使用外部网络和/或卷进行连接。在蓝/绿堆栈定义中,使用变量来配置该堆栈独有的任何内容,例如您的端口。这将是我推荐的解决方案,因为它允许您轻松地将更多服务添加到组合中,并使用相同的 compose 文件在蓝/绿环境之外部署相同的堆栈。
第二种选择是使用 Yaml 的锚和别名语法。
version: '3'
networks:
nw1:
external: false
nw2:
external: true
services:
blue: &service
entrypoint:
- npm
- run
command:
- "start-backend"
- --
- -s
- ${CLIENT_SECRET}
- -c
- ${CLIENT_ID}
- -o
- ${OWNER_ID}
build: .
expose:
- ${BLUE_PORT}
networks:
- nw1
- nw2
environment:
- PORT=${BLUE_PORT}
- CONFIG=live
depends_on:
- mongodb
green:
<<: *service
expose:
- ${GREEN_PORT}
environment:
- PORT=${GREEN_PORT}
- CONFIG=live
mongodb:
image: mongo:3.4
environment:
- MONGO_DATA_DIR=/data/db
- MONGO_LOG_DIR=/dev/null
volumes:
- ./myapplication/data/db:/data/db
command: mongod --smallfiles --logpath=/dev/null # --quiet
networks:
- nw1
最后一个选项是将服务的公共部分定义为扩展字段,然后使用相同的别名和锚语法在 compose 文件中重用它。
version: '3.7'
x-service-common: &service-common
entrypoint:
- npm
- run
command:
- "start-backend"
- --
- -s
- ${CLIENT_SECRET}
- -c
- ${CLIENT_ID}
- -o
- ${OWNER_ID}
build: .
networks:
- nw1
- nw2
depends_on:
- mongodb
networks:
nw1:
external: false
nw2:
external: true
services:
blue:
<<: *service-common
expose:
- ${BLUE_PORT}
environment:
- PORT=${BLUE_PORT}
- CONFIG=live
green:
<<: *service-common
expose:
- ${GREEN_PORT}
environment:
- PORT=${GREEN_PORT}
- CONFIG=live
mongodb:
image: mongo:3.4
environment:
- MONGO_DATA_DIR=/data/db
- MONGO_LOG_DIR=/dev/null
volumes:
- ./myapplication/data/db:/data/db
command: mongod --smallfiles --logpath=/dev/null # --quiet
networks:
- nw1
推荐阅读
- scala - 如何根据 ID 分区计算“Open_Close”col_status =“Colse”的最后/最新关闭日期?
- python - Matplotlib 标题位置
- perl - Perl 使用 grep 匹配文件内容或逐行读取
- c# - 当我尝试运行它时产生的迷宫声音不起作用
- python - 特定模块导入,从带有单独文件的自定义 Python 包中导入,但是:高效思维明确
- angular - 试图从日期对象数组中获取插值中的日期
- .net - 为 Azure 自动化帐户和 Runbook 全局注册自定义类型
- java - Java/C++ 元素数量之和
- ruby - 使用 Nokogiri 抓取多个页面
- flutter - 获取项目点击并传递给另一个类