docker checkpoint是一个试验性的功能,旨在用于测试和反馈,未来不确定是否会发生变化或是被删除掉,现有的功能我们可以简单了解了解。
docker checkpoint主要用于管理检查点(CheckPoint)。检查点(CheckPoint)与恢复(Restore)允许你通过指定一个检查点来冻结一个正在运行的容器,这个检查点将容器的状态转换成磁盘上的一组文件。之后,容器可以从它被冻结的点恢复运行。要想使用检查点,需要先安装CRIU工具,如果是Debian系统,可以使用apt-get安装ppd包。其它系统可以在这里安装。关于Docker中检查点与恢复的历史概览,你可以在Kubernetes的这篇博客文章中找到详细介绍。
目前检查点和恢复功能适用于以下几种情况:
1.在不停止/启动容器的情况下重新启动宿主机
2.加快启动时间较长的应用的启动速度
3.将进程“回滚”到之前的某个时间点
4.对运行中的进程进行“取证调试”
除了Docker之外,检查点与恢复功能的另一个主要使用场景是将服务器从一台机器实时迁移到另一台机器。目前的实现使得这成为可能,但这并不是当前的重点(因此工作流程并没有针对这项任务进行优化)。
下面具体看看docker checkpoint是怎么用的。
首先,我们要知道,docker checkpoint 只是顶级命令,并不能单独使用,需要搭配create、ls和rm三个子命令来使用才算完整。
命令1:docker checkpoint create
docker checkpoint create [OPTIONS] CONTAINER CHECKPOINT
描述:
给一个正在运行中的容器创建新的检查点
选项:
选项 | 描述 |
---|---|
–checkpoint-dir | 使用自定义的检查点存储目录 |
–leave-running | 在创建检查点后保持容器运行 |
命令2:docker checkpoint ls
docker start --checkpoint CHECKPOINT_ID [OTHER OPTIONS] CONTAINER
描述:
查看存在的检查点
选项:
选项 | 描述 |
---|---|
–checkpoint-dir | 使用自定义的检查点存储目录 |
命令3:docker checkpoint rm
docker checkpoint rm
描述:
删除存在的检查点
选项:
选项 | 描述 |
---|---|
–checkpoint-dir | 使用自定义的检查点存储目录 |
1 thought on “【Docker学习】docker checkpoint简单了解”