4

鉴于我在 docker 容器中运行了多个 Web 应用程序,我希望能够让用户在其浏览器中从服务重定向到另一个服务。我想知道如何实现这一点 - 特别是如果我希望我的应用程序可以从一个 docker 主机移植到另一台主机。

假设我们有一个将用户重定向到 ServiceB 的 ServiceA。所以我们有关系

ServiceA --> ServiceB

一种方法是静态分配端口和主机名,并将它们设置为我的 Web 服务的环境变量——我不喜欢这样,因为我不想关心哪个服务在哪个端口上运行。

第二种方法是使用像 nginx 这样的代理并链接服务并使用代理主机和端口。但这需要在将服务移动到其他主机时更改代理配置。

想到的第三种方法是使用 etcd 和大使来注册和解析服务。所以 ServiceA 会使用一个 ServiceB-Ambassador 在 etcd 中查找 ServiceB。这导致许多 docker 容器只是为了连接服务之间。

你更喜欢哪种方式?还是有不同的方法?

编辑

真正的问题是将 ServiceB 的 uri 注入到 ServiceA 中,所以我可以使用类似的参数启动我的 ServiceA -DserviceB.uri=<serviceUri>,以便 serviceA 可以构建正确的重定向标头。

4

1 回答 1

1

我使用 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 来处理事件并进行服务查找?

于 2015-01-10T08:19:50.833 回答