正在手动删除 docker 张图像
Deleting docker images manually
我本地有大约 50K 张图片 ubuntu:
$ docker info
Containers: 3
Images: 49708
Storage Driver: aufs
Root Dir: /var/lib/docker/aufs
Backing Filesystem: extfs
Dirs: 49714
docker rmi -f $(docker images | grep "something" | awk "{print $3}")
占用 100% CPU 并且速度太慢。有什么快速删除大量图片的方法吗?
您似乎需要清理 /var/lib/docker/aufs
。我没有做,这可能是不安全的。
但首先尝试使用 ndk:
编写的这些别名
# Kill all running containers.
alias dockerkillall='docker kill $(docker ps -q)'
# Delete all stopped containers.
alias dockercleanc='printf "\n>>> Deleting stopped containers\n\n" && docker rm $(docker ps -a -q)'
# Delete all untagged images.
alias dockercleani='printf "\n>>> Deleting untagged images\n\n" && docker rmi $(docker images -q -f dangling=true)'
# Delete all stopped containers and untagged images.
alias dockerclean='dockercleanc || true && dockercleani'
# Delete all
alias dockercleanup='dockerkillall || true && dockercleanc || true && dockercleani'
UPD:自此答案发布以来,引入了几种新的手动清理方法。我将允许自己引用 GitHub 用户 adamhadani 的代码(需要 docker-py
):
#!/usr/bin/env python
"""
Check all existing Docker containers for their mapped paths, and then purge any
zombie directories in docker's volumes directory which don't correspond to an
existing container.
"""
import logging
import os
import sys
from shutil import rmtree
import docker
DOCKER_VOLUMES_DIR = "/var/lib/docker/vfs/dir"
def get_immediate_subdirectories(a_dir):
return [os.path.join(a_dir, name) for name in os.listdir(a_dir)
if os.path.isdir(os.path.join(a_dir, name))]
def main():
logging.basicConfig(level=logging.INFO)
client = docker.Client()
valid_dirs = []
for container in client.containers(all=True):
volumes = client.inspect_container(container['Id'])['Volumes']
if not volumes:
continue
for _, real_path in volumes.iteritems():
if real_path.startswith(DOCKER_VOLUMES_DIR):
valid_dirs.append(real_path)
all_dirs = get_immediate_subdirectories(DOCKER_VOLUMES_DIR)
invalid_dirs = set(all_dirs).difference(valid_dirs)
logging.info("Purging %s dangling Docker volumes out of %s total volumes found.",
len(invalid_dirs), len(all_dirs))
for invalid_dir in invalid_dirs:
logging.info("Purging directory: %s", invalid_dir)
rmtree(invalid_dir)
logging.info("All done.")
if __name__ == "__main__":
sys.exit(main())
所以回答我自己的问题,docker contrib 目录中有一个脚本:
https://github.com/docker/docker/blob/620339f166984540f15aadef2348646eee9a5b42/contrib/nuke-graph-directory.sh
运行 它用 sudo 删除了我所有的图像,只需重新启动 docker 守护进程就可以了。
我本地有大约 50K 张图片 ubuntu:
$ docker info
Containers: 3
Images: 49708
Storage Driver: aufs
Root Dir: /var/lib/docker/aufs
Backing Filesystem: extfs
Dirs: 49714
docker rmi -f $(docker images | grep "something" | awk "{print $3}")
占用 100% CPU 并且速度太慢。有什么快速删除大量图片的方法吗?
您似乎需要清理 /var/lib/docker/aufs
。我没有做,这可能是不安全的。
但首先尝试使用 ndk:
编写的这些别名# Kill all running containers.
alias dockerkillall='docker kill $(docker ps -q)'
# Delete all stopped containers.
alias dockercleanc='printf "\n>>> Deleting stopped containers\n\n" && docker rm $(docker ps -a -q)'
# Delete all untagged images.
alias dockercleani='printf "\n>>> Deleting untagged images\n\n" && docker rmi $(docker images -q -f dangling=true)'
# Delete all stopped containers and untagged images.
alias dockerclean='dockercleanc || true && dockercleani'
# Delete all
alias dockercleanup='dockerkillall || true && dockercleanc || true && dockercleani'
UPD:自此答案发布以来,引入了几种新的手动清理方法。我将允许自己引用 GitHub 用户 adamhadani 的代码(需要 docker-py
):
#!/usr/bin/env python
"""
Check all existing Docker containers for their mapped paths, and then purge any
zombie directories in docker's volumes directory which don't correspond to an
existing container.
"""
import logging
import os
import sys
from shutil import rmtree
import docker
DOCKER_VOLUMES_DIR = "/var/lib/docker/vfs/dir"
def get_immediate_subdirectories(a_dir):
return [os.path.join(a_dir, name) for name in os.listdir(a_dir)
if os.path.isdir(os.path.join(a_dir, name))]
def main():
logging.basicConfig(level=logging.INFO)
client = docker.Client()
valid_dirs = []
for container in client.containers(all=True):
volumes = client.inspect_container(container['Id'])['Volumes']
if not volumes:
continue
for _, real_path in volumes.iteritems():
if real_path.startswith(DOCKER_VOLUMES_DIR):
valid_dirs.append(real_path)
all_dirs = get_immediate_subdirectories(DOCKER_VOLUMES_DIR)
invalid_dirs = set(all_dirs).difference(valid_dirs)
logging.info("Purging %s dangling Docker volumes out of %s total volumes found.",
len(invalid_dirs), len(all_dirs))
for invalid_dir in invalid_dirs:
logging.info("Purging directory: %s", invalid_dir)
rmtree(invalid_dir)
logging.info("All done.")
if __name__ == "__main__":
sys.exit(main())
所以回答我自己的问题,docker contrib 目录中有一个脚本: https://github.com/docker/docker/blob/620339f166984540f15aadef2348646eee9a5b42/contrib/nuke-graph-directory.sh
运行 它用 sudo 删除了我所有的图像,只需重新启动 docker 守护进程就可以了。