返回介绍

Swarm模式工作原理 - Task的状态

发布于 2020-09-14 13:05:51 字数 2512 浏览 1306 评论 0 收藏 0

Service是应用运行的理想状态的描述,task在这个理想状态下完成工作。工作按照下面的流程在Swarm节点之间被调度:

  1. 使用CLI运行命令docker service create,或者使用UCP web界面。

  2. 请求传递给manager节点。

  3. manager节点在特定的节点调度service的运行。

  4. 每一个service可以由多个task来执行。

  5. 每一个task都有一个生命周期,生命周期的状态包括:NEWPENDINGCOMPLETE等等。

Task是一次执行单元。当task停止,就不会再被执行,除非一个新的task会取代它。

在task执行完成或者失败之前,task会通过一系列的状态变化。task由NEW状态初始化。task的状态变化过程是不可逆的。例如,一个task是永远不会从COMPLETE状态变回RUNNING状态的。

Task的状态如下表:

状态描述
NEW初始化状态
PENDING资源分配了任务时的状态
ASSIGNEDtask被分配到节点后的状态
ACCEPTEDtask被worker节点接受后的状态。
PREPARINGDocker正在准备task
STARTINGDocker启动task
RUNNING正在运行中的状态
COMPLETEtask已经存在,并且没有错误码
FAILEDtask已经存在,但是有错误码出现
SHUTDOWNDocker被请求关闭task
REJECTEDworker节点拒绝接受task
ORPHANED节点离线时间超长

查看状态

运行命令docker service ps <service-name>来获得task的状态。CURRENT STATE表示task的状态:

  1. $ docker service ps webserver
  2. ID NAME IMAGE NODE DESIRED STATE CURRENT STATE ERROR PORTS
  3. owsz0yp6z375 webserver.1 nginx UbuntuVM Running Running 44 seconds ago
  4. j91iahr8s74p \_ webserver.1 nginx UbuntuVM Shutdown Failed 50 seconds ago "No such container: webserver.…"
  5. 7dyaszg13mw2 \_ webserver.1 nginx UbuntuVM Shutdown Failed 5 hours ago "No such container: webserver.…"

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文