我正在尝试在 AWS 上设置生产就绪集群,该集群使用Jeff Lindsay 的 progrium/docker-consul
映像安装Consul
在每台主机上,但无法将二级和三级服务器连接到-join
初始服务器。
我已经按照生产说明中的运行真正的领事集群,但是i/o timeout
当我的consul2
和consul3
节点尝试访问-join
私有consul1
IP 时出现错误。
实例
我在 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
知道是什么原因造成的吗?我已经重新尝试了大约九次,但仍然没有运气。它确实促使我对网络做更多的学习(这是一个广泛、深入、引人入胜的主题),但我不知道我的配置中是否存在问题,或者这是否是一个实际的错误。
提前感谢您的帮助。