4

我正在尝试从正在运行的 Docker 容器中访问 etcd。当我跑

curl http://172.17.42.1:4001/v2/keys

我明白了

curl: (7) Failed to connect to 172.17.42.1 port 4001: Connection refused

我有四个其他主机可以正常工作,但是这台机器上的每个容器都有这个问题。我真的不知道发生了什么,我不知道如何调试它。

我的 etcd 环境变量是

ETCD_ADVERTISE_CLIENT_URLS=http://10.242.10.2:2379
ETCD_DISCOVERY=https://discovery.etcd.io/<token_removed>
ETCD_INITIAL_ADVERTISE_PEER_URLS=http://10.242.10.2:2380
ETCD_LISTEN_CLIENT_URLS=http://10.242.10.2:2379,http://127.0.0.1:2379,http://0.0.0.0:4001
ETCD_LISTEN_PEER_URLS=http://10.242.10.2:2380

我也可以从主机访问 etcd

curl http://localhost:4001/v2/keys

所以从容器路由到主机时似乎出现了一些错误。但我无法弄清楚它是什么。谁能指出我正确的方向?

4

2 回答 2

7

我观察到我必须使用 --advertise-client-urls 和 --listen-client-urls。像这样:

./etcd --advertise-client-urls 'http://0.0.0.0:2379,http://0.0.0.0:4001' --listen-client-urls 'http://0.0.0.0:2379,http://0.0.0.0:4001'

然后我能够成功地做到

curl -L http://hostname:2379/version

从可以到达该服务器的任何机器上运行。

于 2016-06-16T15:42:35.037 回答
3

事实证明,etcd 只是localhost:4001在那台机器上侦听,这就是为什么我无法从容器内访问它的原因。尽管我将侦听客户端 URL 之一配置为0.0.0.0:4001.

事实证明我已经运行了sudo systemctl enable etcd2,这导致它在 cloud-config 服务运行之前运行。因此,etcd 从默认配置开始,而不是我在云配置中指定的配置。运行sudo systemctl disable etcd2解决了这个问题。

于 2015-10-14T21:59:36.597 回答