- 确保您了解如何 。
列出 DaemonSet 的所有版本:
该命令返回 DaemonSet 版本列表:
- daemonsets "<daemonset-name>"
- REVISION CHANGE-CAUSE
- 1 ...
- 2 ...
- ...
- kubectl rollout history daemonset <daemonset-name> --revision=1
该命令返回相应版本的详细信息:
- # 在 --to-revision 中指定您从步骤 1 中获取的版本序号
- kubectl rollout undo daemonset <daemonset-name> --to-revision=<revision>
如果成功,命令会返回:
- daemonset "<daemonset-name>" rolled back
kubectl rollout undo daemonset 向服务器表明启动 DaemonSet 回滚。 真正的回滚是在服务器端异步完成的。
执行以下命令,来观察 DaemonSet 回滚进度:
回滚完成时,输出形如:
- daemonset "<daemonset-name>" successfully rolled out
在前面的 kubectl rollout history 步骤中,您获得了一个版本列表,每个版本都存储在名为 ControllerRevision 的资源中。 ControllerRevision 仅在 Kubernetes 1.7 及以后的版本中可用。
- kubectl get controllerrevision -l <daemonset-selector-key>=<daemonset-selector-value>
该命令返回 ControllerRevisions 列表:
每个 ControllerRevision 中存储了相应 DaemonSet 版本的注解和模板。
kubectl rollout undo 采用特定 ControllerRevision ,并用 ControllerRevision 中存储的模板代替 DaemonSet 的模板。 kubectl rollout undo 相当于通过其他命令(如 kubectl edit 或 kubectl apply)将 DaemonSet 模板更新至先前的版本。
注意 DaemonSet 版本只会向前滚动。 也就是说,回滚完成后,所回滚到的 ControllerRevision 版本号 (.revision 字段) 会增加。 例如,如果用户在系统中有版本 1 和版本 2,并从版本 2 回滚到版本 1 ,带有 .revision: 1 的ControllerRevision 将变为 .revision: 3。