0

nginx を使用して docker swarm クラスターを正常にセットアップしました。私のec2インスタンスで。このチュートリアルを使用して

https://botleg.com/stories/load-balancing-with-docker-swarm/

私はこのように使用しています

マネージャー 1

ノード 1

ノード 2

サービス検出のために登録者と一緒にコンソールを使用しています。

Consul Machine docker run --restart=unless-stopped -d -p 8500:8500 -h consul progrium/consul -server -bootstrap

Swarm Manager docker run --restart=unless-stopped -d -p 3375:2375 swarm manage --replication --advertise=mangerip:3375 consul://consulip:8500/

docker run --restart=unless-stopped -d --name=registrator -h=host --volume=/var/run/docker.sock:/tmp/docker.sock gliderlabs/registrator:latest consul://consulip: 8500

Node1 docker run --restart=unless-stopped -d swarm join --advertise=node1ip:2375 consul://consulip:8500/

docker run --restart=unless-stopped -d --name=registrator -h=host --volume=/var/run/docker.sock:/tmp/docker.sock gliderlabs/registrator:latest consul://consulip: 8500

Node2 docker run --restart=unless-stopped -d swarm join --advertise=node2:2375 consul://consulip:8500/

docker run --restart=unless-stopped -d --name=registrator -h=host --volume=/var/run/docker.sock:/tmp/docker.sock gliderlabs/registrator:latest consul://consulip: 8500

私の Dockerfile

FROM nginx:latest

RUN apt-get update \
  && apt-get install -y unzip

ADD files/start.sh /bin/start.sh
RUN chmod +x /bin/start.sh
ADD files/default.ctmpl /templates/default.ctmpl

ADD https://releases.hashicorp.com/consul-template/0.12.2/consul-template_0.12.2_linux_amd64.zip /usr/bin/
RUN unzip /usr/bin/consul-template_0.12.2_linux_amd64.zip -d /usr/local/bin

EXPOSE 80
ENTRYPOINT ["/bin/start.sh"]

start.sh

#!/bin/bash
service nginx start
consul-template -consul=$CONSUL_URL -template="/templates/default.ctmpl:/etc/nginx/conf.d/default.conf:service nginx reload"

デフォルト.ctmpl

{{$app := env "APP_NAME"}}

upstream {{printf $app}} {
    least_conn;
    {{range service $app}}
    server {{.Address}}:{{.Port}} max_fails=3 fail_timeout=60 weight=1;{{end}}
}

server {
    listen 80 default;

    location / {
        proxy_pass http://{{printf $app}};
    }
}

docker-compose.yml

version: '2'

services:
  lb:
    build: .
    container_name: lb
    ports:
      - "80:80"
    environment:
      - APP_NAME=tutum-nodejs-redis
      - CONSUL_URL=${KV_IP}:8500
    depends_on:
      - web
    networks:
      - front-tier

  web:
    image: hanzel/tutum-nodejs-redis
    ports:
      - "4000"
    environment:
      - APP_PORT=4000
      - REDIS_IP=redis
      - REDIS_PORT=6379
    depends_on:
      - redis
    networks:
      - front-tier
      - back-tier

  redis:
    image: redis
    container_name: redis
    command: redis-server --appendonly yes
    volumes:
      - redis-data:/data
    networks:
      - back-tier

volumes:
  redis-data:
    driver: local

networks:
  front-tier:
    driver: overlay
  back-tier:
    driver: overlay

これに関する問題は、Docker がノードを自動的に選択するため、A レコードを指す必要がある IP アドレスです。

これを初めて実行すると、最初のノードが選択される場合があります。これを削除してすべての手順をやり直すと、別のノードと別の IP が選択されます。そのときは A レコードを変更する必要があります。この問題をどのように解決するか、

私はそれをグーグルで検索し、waglを見つけました。これにより、DNS ベースのサービス検出が可能になりました。これは素晴らしいことです。しかし、それは非常に基本的なものだったと思います。それが本番環境にあったかどうかはわかりません。

AからZまでの流れ、つまり、展開からAレコードへのIPアドレスの設定までを行う方法を誰か教えてください。または、リンクを教えてください。

4

1 に答える 1

2

そのためのレコードを変更する必要はないと思います。クラスターの IP アドレスは既にわかっているため、使用してデプロイする場合は、ロード バランサー環境にdocker-composeを追加できます。constraintconstraint:node==node1

于 2016-04-22T11:15:42.997 に答える