我使用 consul 的设置将 tomcat 容器连接到 apache http 服务器(使用 mod_jk )。Consul 类似于 etcd,即它允许注册和发现服务。这可能适用于您的问题,但您不仅限于领事。
每次启动一个新的 tomcat 容器时,我都会为该容器分配一个不同的公共端口,在 consul 中注册 tomcat 容器并使用有关其 IP 和端口的信息并触发一个事件(脚本在 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"
在领事(在 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 和端口),创建一个新的 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
您能否使用一种方法,让您的服务在 consul(或 etcd)中注册并通过事件和服务查找来发现彼此。还是使用 nginx 来处理事件并进行服务查找?