snapshot服务负责构建容器运行的文件系统,使用多种graphdriver挂载多层文件系统。
1. snapshot服务能力
Prepare(ctx context.Context, key, parent string, opts ...Opt) ([]mount.Mount, error)
View(ctx context.Context, key, parent string, opts ...Opt) ([]mount.Mount, error)
Commit(ctx context.Context, name, key string, opts ...Opt) error
Remove(ctx context.Context, key string) error
Walk(ctx context.Context, fn WalkFunc, filters ...string) error
Mounts(ctx context.Context, key string) ([]mount.Mount, error)
Usage(ctx context.Context, key string) (Usage, error)
Close() error
1)Prepare
创建活跃的snapshot,以overlay挂载驱动为例,创建upper layer层文件目录,并且返回lower、upper层的mount信息,但该方法并没有挂载文件目录。
2)Commit
将创建的snapshot的upper layer层标记为commit类型,可以供其他snapshot使用。3) View
与Prepare的实现基本相同,只是将mount标记为only read,View生成的只读快照不能调用Commit进行提交。
4)Walk
遍历所有的snapshot 过滤后,执行WalkFunc方法。
2. boltdb Key、Value键值对。
1)metadata存储(/var/lib/containerd/io.containerd.snapshotter.v1.overlayfs/meta.db
):
Key: v1/{ns}/snapshots/{driver}/{key}
Value: parent、children、createdat、createdat
- snapshot 存储(
/var/lib/containerd/io.containerd.snapshotter.v1.overlayfs/metadata.db
)
Key: v1/parents
Key1: pid + id, Value: {key}
Key: v1/snapshots
Key1: {ns}/{id}/{key}
Vaule: kind、id、inodes、size
操作测试:
// 第一次提交 (根)
$# ctr snapshot prepare activeLayer0 // prepare 创建一个工作状态的层
$# ctr snapshot mount /var/lib/containerd/custom_dir activeLayer0 | xargs sudo // snapshot 文件系统挂载(此挂载类型overlayfs)
$# echo “1" > ./custom_dir/add01 // 增加一次变更文件
$# umount /var/lib/containerd/custom_dir // 卸载点
$# ctr snapshot commit commit_add01 activeLayer0 // 提交 committed,变更snapshot状态,保存Layer
// 第二次提交,以第一次 layer 为 parent
$# ctr snapshot prepare activeLayer0 commit_add01
$# ctr snapshot mount /var/lib/containerd/custom_dir activeLayer0 | xargs sudo
$# echo "2" > /var/lib/containerd/custom_dir/add02
$# umount /var/lib/containerd/custom_dir
$# ctr snapshot commit commit_add02 activeLayer0
参考链接: https://www.jianshu.com/p/0a91b209a04c