私は、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 を使用してイベントを処理し、サービス ルックアップを行いますか?