2

我正在尝试在 AWS 上设置生产就绪集群,该集群使用Jeff Lindsay 的 progrium/docker-consul映像安装Consul在每台主机上,但无法将二级和三级服务器连接到-join初始服务器。

我已经按照生产说明中的运行真正的领事集群,但是i/o timeout当我的consul2consul3节点尝试访问-join私有consul1IP 时出现错误。

实例

我在 AWS 上启动了三个t2.micros,并在我的 VPC 中分配了以下私有 IP:

172.31.4.194 (Intended to be `consul1`, leader)
172.31.4.195 (Intended to be `consul2`)
172.31.4.193 (Intended to be `consul3`)



启动初始 Consul 服务器实例

我的consul1节点自己启动并等待其他两个就好了:

sudo docker run -d -h consul1 --name consul1 -v /mnt:/data \
    -p 172.31.4.194:8300:8300 \
    -p 172.31.4.194:8301:8301 \
    -p 172.31.4.194:8301:8301/udp \
    -p 172.31.4.194:8302:8302 \
    -p 172.31.4.194:8302:8302/udp \
    -p 172.31.4.194:8400:8400 \
    -p 172.31.4.194:8500:8500 \
    -p 172.17.42.1:53:53/udp \
    progrium/consul -server -advertise 172.31.4.194-bootstrap-expect 3



尝试run第二个服务器实例

但是当我尝试启动我的consul2节点时,使用以下命令:

sudo docker run -d -h consul2 --name consul2 -v /mnt:/data \
    -p 172.31.4.195:8300:8300 \
    -p 172.31.4.195:8301:8301 \
    -p 172.31.4.195:8301:8301/udp \
    -p 172.31.4.195:8302:8302 \
    -p 172.31.4.195:8302:8302/udp \
    -p 172.31.4.195:8400:8400 \
    -p 172.31.4.195:8500:8500 \
    -p 172.17.42.1:53:53/udp \
    progrium/consul -server -advertise 172.31.4.195 -join 172.31.4.194



错误

这是我得到的错误:

==> WARNING: It is highly recommended to set GOMAXPROCS higher than 1
==> Starting raft data migration...
==> Starting Consul agent...
==> Starting Consul agent RPC...
==> Joining cluster...
==> dial tcp 172.31.4.194:8301: i/o timeout



知道是什么原因造成的吗?我已经重新尝试了大约九次,但仍然没有运气。它确实促使我对网络做更多的学习(这是一个广泛、深入、引人入胜的主题),但我不知道我的配置中是否存在问题,或者这是否是一个实际的错误。

提前感谢您的帮助。

4

1 回答 1

4

问题解决了!

原来我忘记打开Consul需要在管理实例访问的安全组中使用的端口。

打开8300, 8301, 8302, 8400,8500和所有安装都很好。

于 2015-06-19T22:44:07.333 回答