我可以避免重复我的服务定义进行蓝绿部署吗?

问题描述 投票:1回答:1

我正在研究一种简单的蓝绿色部署应用程序后端的方法。我从一开始就为后端编写了一个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
docker docker-compose
1个回答
0
投票

夫妻不同的选择。首先,您可以创建两个完全独立的堆栈,一个用于蓝色,另一个用于绿色。您需要将其外的任何公共服务移动到第三个公共堆栈中,并使用外部网络和/或卷进行连接。在蓝色/绿色堆栈定义中,使用变量来配置该堆栈的唯一内容,例如您的端口。这将是我推荐的解决方案,因为它允许您轻松地向混合添加更多服务,并使用相同的撰写文件在蓝/绿环境之外部署相同的堆栈。

第二个选项是使用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

最后一个选项是将服务的公共部分定义为extension field,然后使用相同的别名和锚语法在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
© www.soinside.com 2019 - 2024. All rights reserved.