- 前言
- 概述
- Swarm模式关键概念
- 开始使用Swarm
- 开始使用Swarm - 安装
- 开始使用Swarm - 创建Swarm
- 开始使用Swarm - 增加节点
- 开始使用Swarm - 发布service
- 开始使用Swarm - 查看service的状态
- 开始使用Swarm - 服务中task的数量
- 开始使用Swarm - 删除service
- 开始使用Swarm - 滚动式更新
- 开始使用Swarm - DRAIN状态的节点
- 开始使用Swarm - Swarm模式端口路由网
- Swarm模式工作原理
- Swarm模式工作原理 - 节点工作原理
- Swarm模式工作原理 - Service工作原理
- Swarm模式工作原理 - 安全(PKI)
- Swarm模式工作原理 - Task的状态
- Swarm管理维护指南
- Swarm管理维护指南 - Swarm中的Manger节点
- Swarm管理维护指南 - 灾备恢复
- Swarm管理维护指南 - 其他
- 其他
- 其他 - Worker节点负载均衡
- 其他 - 强制平衡
- 其他 - 强行移除节点
- 其他 - Manager节点配置静态IP地址
- 其他 - 分布式manager节点
- 其他 - Manager节点的故障排查
- 其他 - 监控Swarm健康
- 其他 - 备份
文章来源于网络收集而来,版权归原创者所有,如有侵权请及时联系!
Swarm模式工作原理 - Task的状态
Service是应用运行的理想状态的描述,task在这个理想状态下完成工作。工作按照下面的流程在Swarm节点之间被调度:
使用CLI运行命令
docker service create
,或者使用UCP web界面。请求传递给manager节点。
manager节点在特定的节点调度service的运行。
每一个service可以由多个task来执行。
每一个task都有一个生命周期,生命周期的状态包括:
NEW
,PENDING
和COMPLETE
等等。
Task是一次执行单元。当task停止,就不会再被执行,除非一个新的task会取代它。
在task执行完成或者失败之前,task会通过一系列的状态变化。task由NEW
状态初始化。task的状态变化过程是不可逆的。例如,一个task是永远不会从COMPLETE
状态变回RUNNING
状态的。
Task的状态如下表:
状态 | 描述 |
---|---|
NEW | 初始化状态 |
PENDING | 资源分配了任务时的状态 |
ASSIGNED | task被分配到节点后的状态 |
ACCEPTED | task被worker节点接受后的状态。 |
PREPARING | Docker正在准备task |
STARTING | Docker启动task |
RUNNING | 正在运行中的状态 |
COMPLETE | task已经存在,并且没有错误码 |
FAILED | task已经存在,但是有错误码出现 |
SHUTDOWN | Docker被请求关闭task |
REJECTED | worker节点拒绝接受task |
ORPHANED | 节点离线时间超长 |
查看状态
运行命令docker service ps <service-name>
来获得task的状态。CURRENT STATE
表示task的状态:
$ docker service ps webserver
ID NAME IMAGE NODE DESIRED STATE CURRENT STATE ERROR PORTS
owsz0yp6z375 webserver.1 nginx UbuntuVM Running Running 44 seconds ago
j91iahr8s74p \_ webserver.1 nginx UbuntuVM Shutdown Failed 50 seconds ago "No such container: webserver.…"
7dyaszg13mw2 \_ webserver.1 nginx UbuntuVM Shutdown Failed 5 hours ago "No such container: webserver.…"
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论