docker создать для запуска нескольких служб API в одной базе данных - PullRequest
0 голосов
/ 15 января 2020

docker составьте файл, состоящий из фиктивного сервера mountebank, одной базы данных postgres, одной службы API A, одной службы API B

детали:

version: '3'
networks:
  sgqa:
services:
  eureka-server:
    networks: 
      - sgqa
    image: nexus.app.net:8083/server:1.1
    container_name: eureka
    hostname: eureka
    ports:
      - "8761:8761"
      
  config-server-mountebank:
    networks: 
      - sgqa
    image: jkris/mountebank:latest
    container_name: configserver
    hostname: configserver
    ports:
      - "2525:2525"
      - "8888:8888"
    volumes:
      - ./testimposters.postgres.ejs:/imposters/imposters.ejs
    command: --configfile /imposters/imposters.ejs --allowInjection
    
  postgres:
    networks: 
      - sgqa
    image: postgres
    container_name: postgres
    volumes:
      - ./testinit.sql:/docker-entrypoint-initdb.d/init.sql
    ports:
      - "5432:5432"
    environment:
      POSTGRES_USER: test
      POSTGRES_PASSWORD: test
      
  zookeeper:
    networks: 
      - sgqa
    image: wurstmeister/zookeeper
    hostname: zookeeper
    container_name: zookeeper
    ports:
      - "2181:2181"
    environment:
      ZOOKEEPER_CLIENT_PORT: 2181
      ZOOKEEPER_TICK_TIME: 2000
      ALLOW_ANONYMOUS_LOGIN: 1
  
  kafka:
    networks: 
      - sgqa
    image: wurstmeister/kafka
    hostname: kafka
    container_name: kafka
    depends_on:
      - zookeeper
    ports:
      - "9092:9092"
    environment:
      KAFKA_ZOOKEEPER_CONNECT: 'zookeeper:2181'
      KAFKA_AUTO_CREATE_TOPICS_ENABLE: 'true'
      ALLOW_PLAINTEXT_LISTENER: 'yes'
      KAFKA_ADVERTISED_HOST_NAME: kafka

  schema-registry:
    networks: 
      - sgqa
    image: confluentinc/cp-schema-registry:5.2.1
    hostname: schema-registry
    container_name: schema-registry
    depends_on:
      - zookeeper
      - kafka
    ports:
      - "8081:8081"
    environment:
      SCHEMA_REGISTRY_HOST_NAME: 'schema-registry'
      SCHEMA_REGISTRY_KAFKASTORE_CONNECTION_URL: 'zookeeper:2181'

  rest-proxy:
    networks: 
      - sgqa
    image: confluentinc/cp-kafka-rest:5.2.1
    depends_on:
      - zookeeper
      - kafka
      - schema-registry
    ports:
      - "8082:8082"
    hostname: rest-proxy
    container_name: rest-proxy
    environment:
      KAFKA_REST_HOST_NAME: 'rest-proxy'
      KAFKA_REST_BOOTSTRAP_SERVERS: 'kafka:9092'
      KAFKA_REST_LISTENERS: "http://rest-proxy:8082"
      KAFKA_REST_SCHEMA_REGISTRY_URL: 'http://schema-registry:8081'
      KAFKA_REST_ZOOKEEPER_CONNECT: 'zookeeper:2181' 

  appA:
    networks: 
      - sgqa
    build:
        context: appAService/
        dockerfile: ./appA/Dockerfile
    image: appA:latest
    hostname: appA
    depends_on:
      - postgres
      - config-server-mountebank
      - zookeeper
      - kafka
      - schema-registry
      - rest-proxy
    ports:
      - "8015:8015"
    container_name: appA

  appB:
    networks: 
      - sgqa
    build:
        context: appBService/
        dockerfile: ./appB/Dockerfile
    image: appB:latest
    hostname: appB
    depends_on:
      - postgres
      - config-server-mountebank
      - zookeeper
      - kafka
      - schema-registry
      - rest-proxy
    ports:
      - "8010:8010"
    container_name: appB

при запуске appA, новая схема A создается в тестовой БД.

при запуске appB новая схема B создается в той же тестовой БД.

запустив выше docker compose, я обнаружил, что схема B создана, схема A - нет. Я не уверен, что схема A когда-либо создавалась или перезаписывалась схемой B.

Кто-нибудь мог бы посоветовать, почему это произошло? без схемы A appA не будет работать должным образом.

или что-то не так с ключом "disabled_on" в файле docker compose?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...