-1

我有一个 go-micro 服务,我希望它在容器中运行的 Consul 上注册。仅从命令提示符执行此操作时,它运行良好。我检查了 consul-container 的日志,发现一切正常。注册和注销:

 2018/08/06 08:54:44 [WARN] agent: Service name "myservice.ucum-service" will not be discoverable via DNS due to invalid characters. Valid characters include all alpha-numerics and dashes.
 2018/08/06 08:54:44 [INFO] agent: Synced service "myservice.ucum-service-5d4543b5-9956-11e8-a484-5404a6f49407"
 2018/08/06 08:54:44 [INFO] agent: Synced check "service:myservice.ucum-service-5d4543b5-9956-11e8-a484-5404a6f49407"
 2018/08/06 08:54:53 [INFO] agent: Deregistered service "myservice.ucum-service-5d4543b5-9956-11e8-a484-5404a6f49407"
 2018/08/06 08:54:53 [INFO] agent: Deregistered check "service:myservice.ucum-service-5d4543b5-9956-11e8-a484-5404a6f49407"

如您所见,它抱怨无效字符。我不知道这意味着什么,但它运行良好,我可以毫无问题地从服务客户端运行我的测试。所以我们可以假设 Consul 容器运行良好。

但现在我的问题。我也想在容器中运行服务,但出现了问题。这是我的服务的 Dockerfile:

FROM debian:stretch
MAINTAINER Bert Verhees "xxxxx@xxxxx.xx"
ADD archibold_ucum_service /archibold_ucum_service
ADD data/ucum-essence.xml /data/ucum-essence.xml
ENTRYPOINT ["/archibold_ucum_service", "-ucumfile=/data/ucum-essence.xml"]

如您所见,服务需要以参数启动,这也没有问题。

当我启动这个容器时,它似乎运行良好,但是当我查看 consul-logs 时,它从未见过它。服务容器的日志告诉我原因。我以这种方式启动容器:

docker run -d --name=ucum_micro_service ucum_micro_service

它得到一个非常好的容器 ID。所以看起来不错,但是查看日志,会发生这种情况:

2018/08/06 09:51:42 Listening on [::]:46517
2018/08/06 09:51:42 Broker Listening on [::]:38283
2018/08/06 09:51:42 Registering node: myservice.ucum-service-52a66d2c-995e-11e8-bb3a-0242ac110002
2018/08/06 09:51:42 Put http://127.0.0.1:8500/v1/agent/service/register: dial tcp 127.0.0.1:8500: connect: connection refused

所以我的想法是它无法突破容器。但是我该如何解决这个问题呢?

非常感谢帮助,谢谢

4

1 回答 1

1

除非您在 docker run 命令中使用 --network=host,否则容器中的 localhost 与您机器上的 localhost 不同。就像 docker 为您的容器创建一个“单独的”文件系统一样,它对网络也是如此。

因此,无论您使用docker run --network=host -d --name=ucum_micro_service ucum_micro_service,您也在容器中运行其他服务并使用 docker networks / links 或类似的东西来连接它们,或者您使用您机器的公共 ip(您可以将其作为参数传递)。

于 2018-08-06T10:03:49.317 回答