4

Docker コンテナーで複数の Web アプリケーションを実行していることを考えると、ユーザーをブラウザーのサービスから別のサービスにリダイレクトできるようにしたいと考えています。これをどのように達成するのだろうか-特に、アプリケーションをあるdockerホストから別のホストに移植できるようにしたい場合。

ユーザーを ServiceB にリダイレクトする ServiceA があるとします。だから私たちは関係を持っています

ServiceA --> ServiceB

1 つのアプローチは、ポートとホスト名を静的に割り当て、環境変数として Web サービスに設定することです。これは、どのサービスがどのポートで実行されるかを気にしたくないため、好みません。

2 番目のアプローチは、nginx のようなプロキシを使用してサービスをリンクし、プロキシのホストとポートを使用することです。ただし、これには、サービスを別のホストに移動するときにプロキシ構成を変更する必要があります。

思いつく 3 番目のアプローチは、etcd とアンバサダーを使用してサービスを登録および解決することです。そのため、ServiceA は、etcd で ServiceB を検索する ServiceB-Ambassador を使用します。これにより、サービス間を接続するためだけに多くの docker コンテナーが作成されます。

あなたはどちらの方法を好みますか?それとも、さまざまなアプローチがありますか?

編集

本当の問題は、ServiceB の uri を ServiceA に挿入することです。そのため、ServiceA を のような引数で起動して-DserviceB.uri=<serviceUri>、serviceA が正しいリダイレクト ヘッダーを作成できるようにします。

4

1 に答える 1

1

私は、consul でセットアップを使用して、Tomcat コンテナーを Apache http サーバーに接続します ( mod_jk を使用)。Consul は etcd に似ています。つまり、サービスの登録と発見が可能です。これはあなたの質問に当てはまるかもしれませんが、あなたは領事に限定されません。

新しい tomcat コンテナーが開始されるたびに、そのコンテナーに個別のパブリック ポートを割り当て、その IP とポートに関する情報を使用して tomcat コンテナーを consul に登録し、イベントを発生させます (スクリプトは Docker ホストで実行され、可読性)

#!/bin/bash
INTERNAL_PORT=8009
source ~/ports.properties
TOMCAT_PORT=$(( TOMCAT_PORT + 1))
echo "TOMCAT_PORT=$TOMCAT_PORT" > ~/ports.properties

CONTAINER_ID=$(docker run -d -p $TOMCAT_PORT:8009 -v `pwd`$WAR_DIR:/webapps rossbachp/tomcat8)
echo "Container started, CONTAINER_ID:  $CONTAINER_ID"

IP_ADDRESS=$(docker inspect -f '{{.NetworkSettings.IPAddress}}' $CONTAINER_ID )
echo "Container IP_ADDRESS:               $IP_ADDRESS "

echo "Register Container in Consul"
curl -X PUT -d '{"ID": "'$CONTAINER_ID'","Name":"'$CLUSTER_NAME'", "Tags": [ "IP_'$IP_ADDRESS'", "PORT_'$INTERNAL_PORT'"],"Port":'$TOMCAT_PORT'}' localhost:8500/v1/agent/service/register 

echo "Fire Event"
consul event -name "TomcatServiceUp"

consul (docker ホスト上) で、スクリプトを実行するファイル /etc/consul.d/bootstrap/watchTomcatServiceUp.json でイベント「TomcatServiceUp」の監視を定義しました。

{
"watches":[    {
"type":"event",
"name":"TomcatServiceUp",
"handler": "/home/dude/docker/docker-http-withmodjk/callbackTomcatServiceUpEvent.sh"
   }  ]
}

そして、スクリプト callbackTomcatServiceUpEvent.sh は、サービス (主に IPAddress と Port) をクエリし、新しい workers.properties ファイルを作成し、このファイルを http docker インスタンス (そのボリューム) にコピーして、http サーバー (docker コンテナー内) を適切に再起動します。

#!/bin/bash
SERVICE=$(curl localhost:8500/v1/agent/services)
java -jar /home/dude/docker/JSonParser.jar "$SERVICE" >> /tmp/workers.properties
cp workers.properties /home/dude/docker/docker-http-withmodjk/mod_jk_conf
# http graceful restart

サービスが自分自身を領事 (または etcd) に登録し、イベントとサービス ルックアップを介してお互いを発見するアプローチを使用できますか。または、nginx を使用してイベントを処理し、サービス ルックアップを行いますか?

于 2015-01-10T08:19:50.833 に答える