docker swarm leader 节点关机后 reachable节点执行node命令会报错 集群没有leader
时间: 2024-02-11 19:04:34 浏览: 172
当 Docker Swarm Leader 节点关闭后,集群的状态会变为没有 Leader 节点。此时,在任何一个节点上执行 `docker node` 命令都会报错,提示集群没有 Leader 节点。这是因为 `docker node` 命令需要与 Leader 节点进行通信才能正常运行,而没有 Leader 节点时,命令就无法执行了。
要解决这个问题,可以通过以下步骤重新选举 Leader 节点:
1. 确认当前 Leader 节点已经离线,使用以下命令查看 Swarm 集群状态:
```
docker node ls
```
如果当前 Leader 节点状态为 Down,则说明该节点已经离线。
2. 在任何一个 Manager 节点上执行以下命令重新选举 Leader 节点:
```
docker swarm init --force-new-cluster
```
这个命令会重新初始化 Swarm 集群,并选举出一个新的 Leader 节点。需要注意的是,这个命令会清除所有的 Swarm 配置,包括服务、网络和卷等。如果你之前已经创建了 Swarm 服务、网络和卷等资源,需要重新创建它们。
3. 在其他 Manager 节点上使用以下命令将它们加入到新的 Swarm 集群中:
```
docker swarm join --token <TOKEN> <MANAGER-IP>:<MANAGER-PORT>
```
其中,`<TOKEN>` 是从 Leader 节点处获取的 Swarm Token,`<MANAGER-IP>` 和 `<MANAGER-PORT>` 是 Leader 节点的 IP 地址和端口号。
4. 等待所有 Manager 节点加入到新的 Swarm 集群中,并使用以下命令检查 Swarm 集群状态:
```
docker node ls
```
如果所有 Manager 节点都处于 Ready 状态,且其中一台节点成为了 Leader 节点,则说明问题已经解决。
需要注意的是,为了保证 Swarm 集群的高可用性和稳定性,建议至少使用三台 Manager 节点,并将它们分布在不同的物理或虚拟机上。这样即使一台 Manager 节点出现故障,也不会影响整个 Swarm 集群的运行。
阅读全文