如何在CoreOS上的Docker映像中从快照还原etcd集群?

阿尔米

我在vmware上有一个带有3个节点的etcd集群(etcd版本3.1.5)的Kubernetes集群(v1.5.6)。这个etcd节点在vmware上的coreos上的三个docker容器中(在三个主机上)运行。

我尝试使用以下解决方案备份etcd:

docker run --rm --net=host -v /tmp:/etcd_backup -e ETCDCTL_API=3 quay.io/coreos/etcd:v3.1.5 etcdctl --endpoints=[1.1.1.1:2379,2.2.2.2:2379,3.3.3.3:2379] snapshot save etcd_backup/snapshot.db

备份已成功完成。

我想在另一个vmware环境中从零创建这个kubernetes集群,但是为此我需要从快照还原etcd。

到目前为止,我还没有在Docker容器中找到适用于etcd的正确解决方案。

我尝试使用以下方法还原,但是很遗憾,我没有成功。

首先,我运行以下命令后创建了一个新的etcd节点:

docker run --rm --net=host -v /tmp/etcd_bak:/etcd_backup -e ETCDCTL_API=3 registry:5000/quay.io/coreos/etcd:v3.1.5 etcdctl snapshot restore etcd_backup/snapshot.db --name etcd0 --initial-cluster etcd0=http://etcd0:2380,etcd1=http://etcd1:2380,etcd2=http://etcd2:2380 --initial-cluster-token etcd-cluster-1 --initial-advertise-peer-urls http://etcd0:2380

结果:

2018-06-04 09:25:52.314747 I | etcdserver/membership: added member 7ff5c9c6942f82e [http://etcd0:2380] to cluster 5d1b637f4b7740d5
2018-06-04 09:25:52.314940 I | etcdserver/membership: added member 91b417e7701c2eeb [http://etcd2:2380] to cluster 5d1b637f4b7740d5
2018-06-04 09:25:52.315096 I | etcdserver/membership: added member faeb78734ee4a93d [http://etcd1:2380] to cluster 5d1b637f4b7740d5

不幸的是,什么也没有发生。

恢复etcd备份的最佳解决方案是什么?

如何创建一个空的etcd群集/节点,如何还原快照?

Kun Li

根据Etcd Disaster Recovery文档,您需要使用诸如您的命令从快照还原所有三个etcd节点,然后使用如下命令运行三个节点:

etcd \
  --name m1 \
  --listen-client-urls http://host1:2379 \
  --advertise-client-urls http://host1:2379 \
  --listen-peer-urls http://host1:2380 &

另外,您可以从图像中提取etcdctl,如下所示:

docker run --rm -v /opt/bin:/opt/bin registry:5000/quay.io/coreos/etcd:v3.1.5 cp /usr/local/bin/etcdctl /opt/bin

然后使用etcdctl还原快照:

# ETCDCTL_API=3 ./etcdctl snapshot restore snapshot.db \
  --name m1 \
  --initial-cluster m1=http://host1:2380,m2=http://host2:2380,m3=http://host3:2380 \
  --initial-cluster-token etcd-cluster-1 \
  --initial-advertise-peer-urls http://host1:2380 \
  --data-dir /var/lib/etcd

这会将快照还原到/ var / lib / etcd目录。然后从docker启动etcd,不要忘记将/ var / lib / etcd挂载到您的容器中,并为其指定--data-dir。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章