关闭和停用节点
关闭和停用代理节点
在 DC/OS 1.12 及更高版本中,删除节点涉及两个步骤:
- 告知 DC/OS 将节点标记为
GONE
- 停止相应的 Mesos 从设备
systemd
单元
UNREACHABLE
状态,因为 Mesos 不知道节点是暂时停止并将重新上线,还是永久停止。如果您知道节点不会返回,您可以明确告诉 Mesos 将节点置于 GONE
状态。
节点停用后,对应的代理 ID 被内部标记为 GONE
并且不允许返回和在管理节点上重新注册。节点上运行的任务已过渡到 TASK_GONE_BY_OPERATOR
状态。如果这些任务使用本地持久卷,一旦被告知代理节点消失,负责框架将放弃这些本地持久卷。它们将在其他合适的代理节点上自动创建带有新的预留和卷的新任务。
您应该在以下情况下停用节点。
-
您在删除节点,尤其是删除多个节点时。DC/OS 配置为每 20 分钟仅允许标记一个节点为
UNREACHABLE
,因此,如果您不是明确地停用节点,则可能需要较长时间 Mesos 才能将您的节点标记为UNREACHABLE
并允许服务在另一节点上重新安排任务。 - 如果您正使用有状态服务,如 DC/OS 数据服务。有状态服务重新安排任务代价昂贵,所以服务需要在重新安排前知道代理不会再次返回在线。
- 当节点以意外停工时。
从 DC/OS CLI 中输入以下命令,以告诉 Mesos 将节点标记为
dcos node
GONE
。
节点被停用后(这与使用
dcos node decommission <mesos-agent-id>
MARK_AGENT_GONE
Mesos API 等同),节点将被告知执行以下任务:
- 关闭 (kill) 代理节点上运行的所有执行程序(任务)
- 停止 Mesos 从进程(但它将被 systemd 自动重新启动)
GONE
并且不允许返回和在管理节点重新注册。任何在节点上运行的任务已过渡到 TASK_GONE_BY_OPERATOR
状态。
# 关闭节点
如果 DC/OS 节点仍在运行,Mesos从进程将继续尝试注册(并且由于代理被标记为已消失,注册会被拒绝)。您可以通过停止 Mesos 从进程(以 systemd
单元运行),停止这些尝试。
- SSH 至代理节点(您希望关闭的)。
- 输入以下命令,停止节点。
- 私有代理
sudo sh -c 'systemctl stop dcos-mesos-slave'
- 公共代理
sudo sh -c 'systemctl stop dcos-mesos-slave-public'