我有一个 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
所以我的想法是它无法突破容器。但是我该如何解决这个问题呢?
非常感谢帮助,谢谢