背景:
在aws部署没问题,dind 部署在腾讯云上,升级到1.24后,jenkins 构建速度特别慢,发现原来只占用10g的磁盘,升级后发现占用超过十倍的存储空间(取决于dockerfile中的层数)。
根因:
aws 中运行的dind 使用的 "storage-driver": "overlay2" ,腾讯云中运行的dind 使用的 "storage-driver": "vfs"
进入容器,执行命令 docker info 可以看到
Storage Driver: vfs (腾讯云)
以下是 vfs 和 overlay2 存储驱动的主要区别:
vfs (Virtual File System)
vfs 是一种非常简单的存储驱动,它将每个容器的文件系统作为一个独立的目录存储在主机文件系统中。
每个容器的文件系统都是一个完整的复制,而不是共享底层文件系统。
overlay2
overlay2 是一种更高级的存储驱动,基于 Linux 内核的 overlay 文件系统。
它使用分层机制,允许多个容器共享相同的镜像层,从而节省磁盘空间和提高启动速度。
看完差异就定位到原因了。
示例yaml
apiVersion: v1
kind: Pod
metadata:
name: clean-ci
spec:
containers:
- name: dind
image: 'docker:stable-dind'
command:
- dockerd
- --host=unix:///var/run/docker.sock
- --host=tcp://0.0.0.0:2376
securityContext:
privileged: true
volumeMounts:
- mountPath: /var/run
name: cache-dir
- mountPath: /var/lib # 挂载目录,使用主机的存储驱动,否则使用默认vfs驱动 或 /var/lib/docker
name: host-lib
- name: clean-ci
image: 'docker:stable'
command: ["/bin/sh"]
args: ["-c", "docker info >/dev/null 2>&1; while [ $? -ne 0 ] ; do sleep 3; docker info >/dev/null 2>&1; done; docker pull library/busybox:latest; docker save -o busybox-latest.tar library/busybox:latest; docker rmi library/busybox:latest; while true; do sleep 86400; done"]
volumeMounts:
- mountPath: /var/run
name: cache-dir
- mountPath: /var/lib # 挂载目录,使用主机的存储驱动,否则使用默认vfs驱动 或 /var/lib/docker
name: host-lib
volumes:
- name: cache-dir
emptyDir: {}
- name: host-lib
hostPath:
path: /data/lib
type: ''