9

ここ数日、Digtital Ocean で Docker swarm の作成に取り組んできました。注: 他のアプリ/コンテナーとの通信には使用したくありません。-link技術的に非推奨と見なされており、docker swarm ではうまく機能しないためです (つまり、アプリケーションを再構成せずにロード バランサーにアプリ インスタンスを追加することはできません)。群れ全体)

このガイドに従って、1 台のサーバーをコンソールを実行する kv-store サーバーとして使用しています。私は Digital Ocean にいるので、マシンが互いに通信できるように、DO でプライベート ネットワークを使用しています。

次に、ハイブ マスターとスレーブを作成し、すべてのマシンで実行されているオーバーレイ ネットワークを開始します。ここに私の docker-compose.yml があります

proxy:
    image: tutum/haproxy 
    ports:
        - "1936:1936"
        - "80:80"

web:
    image: tutum/hello-world
    expose:
        - "80"

したがって、これを行うと、2 つのコンテナーが作成されます。のポート 1936 で統計情報にアクセスできるため、HAProxy は実行されていhttp://<ip-address>:1936ますが、ポート 80 で Web サーバー/ロード バランサーにアクセスしようとすると、接続が拒否されます。私が実行すると、すべてが接続されているようdocker-compose psに見えます:

       Name                      Command               State                                 Ports
--------------------------------------------------------------------------------------------------------------------------------
splashcloud_proxy_1   python /haproxy/main.py          Up      104.236.109.58:1936->1936/tcp, 443/tcp, 104.236.109.58:80->80/tcp
splashcloud_web_1     /bin/sh -c php-fpm -d vari ...   Up      80/tcp

考えられる唯一のことは、Web コンテナーにリンクしていないということですが、これをトラブルシューティングする方法がわかりません。

これについて何か助けていただければ幸いです。

4

2 に答える 2

7

残念ながら、ここでは tutum haproxy バージョンを使用できません。この画像は、特にリンクを中心に調整されています。Web サーバーの IP を haproxy に渡すスクリプト化された方法が必要です。

しかし、これはそれほど難しいことではありません :) この例から始めることをお勧めします: 最初に docker-compose.yml をセットアップします => 2 つのノードを使用できるようにします。途中でバランスをとる:)

proxy:
    build: ./haproxy/
    ports:
        - "1936:1936"
        - "80:80"
web1:
    container_name: web1
    image: tutum/hello-world
    expose:
        - "80"
web2:
    container_name: web2
    image: tutum/hello-world
    expose:
        - "80"

ここで、haproxy を使用して、公式のイメージ ドキュメントに従って独自の Dockerfile をセットアップする必要があります: https://hub.docker.com/_/haproxy/

提案されたファイルを使用して、haproxy サブフォルダーでこれを行いました。

FROM haproxy
COPY haproxy.cfg /usr/local/etc/haproxy/haproxy.cfg

次に、haproxy 構成ファイル haproxy.cfg について、これをテストしました。

global
    stats socket /var/run/haproxy.stat mode 660 level admin
    stats timeout 30s
    user root
    group root

defaults
    mode    http
    timeout connect 5000
    timeout client  50000
    timeout server  50000

frontend localnodes
    bind *:80
    mode http
    default_backend nodes

backend nodes
    mode http
    balance roundrobin
    option forwardfor
    http-request set-header X-Forwarded-Port %[dst_port]
    http-request add-header X-Forwarded-Proto https if { ssl_fc }
    option httpchk HEAD / HTTP/1.1\r\nHost:localhost
    server web01 172.17.0.2:80
    server web02 172.17.0.3:80

listen stats 
    bind *:1936
    mode http
    stats enable
    stats uri /
    stats hide-version
    stats auth someuser:password

明らかに、ここの IP はデフォルト設定でのみ機能します。私はこれを完全に認識しています :) これらの 2 行について何かを行う必要があります。

server web01 172.17.0.2:80
server web02 172.17.0.3:80

ここで Digital Ocean を使用しているのは幸運だと思います :) 私が理解している限りでは、DO を使用してプライベート IP アドレスを自由に使用でき、その下で swarm ノードを実行する予定です。サンプル IP の代わりにこれらのノード IP を単純に配置し、それらで Web サーバーを実行することをお勧めします。それで問題ありません :)

于 2015-12-27T14:58:19.447 に答える
0

docker-compose.yml にリンクを追加する

プロキシー:
    画像:ツタム/ハプロキシ
    ポート:
        - 「1936:1936」
        - 「80:80」
    リンク:
        - ウェブ
ウェブ:
    画像:ツタム/ハローワールド
    公開:
        - 「80」
于 2016-06-18T04:26:47.777 に答える