Невозможно запустить приложение с помощью Docker Swarm, но то же самое работает с помощью Docker-compose - PullRequest
0 голосов
/ 26 ноября 2018

Я пытаюсь создать веб-приложение в Docker.Цель приложения заключается в том, что всякий раз, когда пользователь делает запрос, он должен направляться через nginx на любой из серверов приложений.В настоящее время приложение содержит 3 сервера приложений и 3 сервера базы данных.Ниже приведен список компонентов внутри приложения:

1) MYSQLDB
2) MongoDB
3) RedisDB
4) Load Balancer (nginx)
5) Application Server (Running in Node.js built on top of socket.io)

Ниже приведен файл docker-compose.yml, который успешно создает среду приложения:

version: '3.0'
services:
  appserver1:
      container_name: appserver1
      depends_on:
      - "redis"
      - "mongo"
      - "mariadb"
      build: ./application-module
      tty: true
      volumes:
        - /Volumes:/var/www/html/files
      command: bash -c "sleep 5 && forever app.js"
  appserver2:
      container_name: appserver2
      depends_on:
      - "redis"
      - "mongo"
      - "mariadb"
      build: ./application-module
      tty: true
      volumes:
         - /Volumes:/var/www/html/files
      command: bash -c "sleep 10 && forever app.js"
  appserver3:
      container_name: appserver3
      depends_on:
      - "redis"
      - "mongo"
      - "mariadb"
      build: ./application-module
      tty: true
      volumes:
        - /Volumes:/var/www/html/files
      command: bash -c "sleep 15 && forever app.js"
  adminserver:
      container_name: adminserver
      build: ./admin-module
      tty: true
      volumes:
        - ./var/www/html/files:/var/www/html/files     
  loadbalancer:
      container_name: loadbalancer
      build: ./load-balancer
      tty: true
      links:
          - appserver1
          - appserver2
          - appserver3
      ports:
          - '91:91'
  redis:
      container_name: redisdb
      build: ./redis
      restart: always
      volumes:
        - redisvolume:/data
  mongo:
      container_name: mongodb
      build: ./mongo
    #   environment:
    #       - http_proxy=$http_proxy
    #       - https_proxy=$https_proxy
    #       - no_proxy=$no_proxy
    #       - HTTP_PROXY=$HTTP_PROXY
    #       - HTTPS_PROXY=$HTTPS_PROXY
    #       - NO_PROXY=$NO_PROXY
      volumes:
        - mongovolume:/data/db
  mariadb:
    container_name: mariadb
    image: mariadb:10.3
    restart: always
    volumes:
      - mariadbvolume:/var/lib/mysql
      - ./dump.sql:/docker-entrypoint-initdb.d/dump.sql
    # networks: 
    #  - overlay
    ports: 
    - "3307:3307"
    environment:
      - 'MYSQL_ROOT_PASSWORD=Mys@l123'
      - 'MYSQL_DATABASE=copconnect_dev'
      - 'MYSQL_USER=root'
      - 'MYSQL_PASSWORD=*****'
volumes:
 mariadbvolume:
 mongovolume:
 redisvolume:
 adminvolume:
 appvolume:

Ниже приведен nginx.conffile:

events {
    worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main;

    sendfile        on;
    #tcp_nopush     on;
    client_max_body_size 20M;
    #keepalive_timeout  0;
    keepalive_timeout  65;

    gzip  on;

  server {
   listen 91;
   server_name localhost;

   location / {
    proxy_set_header Upgrade $http_upgrade;
    proxy_set_header Connection "upgrade";
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header Host $host;
    proxy_http_version 1.1;
    proxy_pass http://io_nodes;
            }
    }



    map $http_upgrade $connection_upgrade {
    default upgrade;
    ''      close;
    }



  upstream io_nodes {
  ip_hash;

  server copconnect_appserver.1:3001;

  server copconnect_appserver.2:3001;

  server copconnect_appserver.3:3001;

  }
}

После запуска docker-compose.yml приложение успешно создает платформу и запускает приложение, но когда я пытаюсь выполнить в режиме роя, это создает много проблем - службы не создаются для loadbalancer &appserver.

Найдите файл docker-compose-stack.yml ниже:

version: "3"
services:
  redis:
    image: redis:alpine
    ports:
      - "6379"
    networks:
      - backend
    deploy:
      replicas: 1
      update_config:
        parallelism: 2
        delay: 10s
      restart_policy:
        condition: on-failure
  mariadb:
    image: mariadb:10.3
    volumes:
      - mariadbvolume:/var/lib/mysql
      #- ./dump.sql:/docker-entrypoint-initdb.d/dump.sql
    ports: 
    - "3307:3307"
    environment:
      - 'MYSQL_ROOT_PASSWORD=******'
      - 'MYSQL_DATABASE=copconnect_dev'
      - 'MYSQL_USER=root'
      - 'MYSQL_PASSWORD=********'
    networks:
      - backend
    deploy:
      placement:
        constraints: [node.role == manager]
  mongo:
    image: mongo:latest
    ports: 
    - "27017:27017"
    volumes:
      - mongovolume:/data/db
    networks:
      - backend
    deploy:
      placement:
        constraints: [node.role == manager]
  appserver:
    image: localhost:5000/appserver:latest
    ports:
      - 3001:3001
    volumes:
         - ./var/www/html/files:/var/www/html/files
    networks:
      - backend
    depends_on:
      - redis
      - mongo
      - mariadb
    deploy:
      mode: replicated
      replicas: 3
      labels: [APP=appserver]
      restart_policy:
        condition: on-failure
        delay: 10s
        max_attempts: 3
        window: 120s
      placement:
        constraints: [node.role == manager]

  visualizer:
    image: dockersamples/visualizer
    ports:
      - "8080:8080"
    stop_grace_period: 1m30s
    volumes:
      - "/var/run/docker.sock:/var/run/docker.sock"
    deploy:
      placement:
        constraints: [node.role == manager]
  loadbalancer:
    image: localhost:5000/nginx:1.0
    ports:
      - "91:91"
    stop_grace_period: 1m30s
    networks:
      - backend  
networks:
  backend:

volumes:
  mariadbvolume:
  mongovolume:
  redisvolume:
  appvolume:

При создании кластера swarm и попытке запустить приложение в журналах упоминается, что appserver не может подключиться к базе данных.,Служба loadbalancer не включается, поскольку упоминает, что appserver.1, appserver.2, appserver.3 не существует.

...