这个问题与我是否应该关注过量的、未运行的Docker容器有关。

我想知道如何移除旧容器。docker rm 3e552code34a允许你删除一个,但我已经有很多了。Docker rm——help没有提供选择选项(像all一样,或者通过映像名称)。

也许有一个存放这些容器的目录,我可以很容易地手动删除它们?


当前回答

下面是我的docker-cleanup脚本,它删除未标记的容器和图像。请检查来源的任何更新。

#!/bin/sh
# Cleanup docker files: untagged containers and images.
#
# Use `docker-cleanup -n` for a dry run to see what would be deleted.

untagged_containers() {
  # Print containers using untagged images: $1 is used with awk's print: 0=line, 1=column 1.
  docker ps -a | awk '$2 ~ "[0-9a-f]{12}" {print $'$1'}'
}

untagged_images() {
  # Print untagged images: $1 is used with awk's print: 0=line, 3=column 3.
  # NOTE: intermediate images (via -a) seem to only cause
  # "Error: Conflict, foobarid wasn't deleted" messages.
  # Might be useful sometimes when Docker messed things up?!
  # docker images -a | awk '$1 == "<none>" {print $'$1'}'
  docker images | tail -n +2 | awk '$1 == "<none>" {print $'$1'}'
}

# Dry-run.
if [ "$1" = "-n" ]; then
  echo "=== Containers with uncommitted images: ==="
  untagged_containers 0
  echo

  echo "=== Uncommitted images: ==="
  untagged_images 0

  exit
fi

# Remove containers with untagged images.
echo "Removing containers:" >&2
untagged_containers 1 | xargs --no-run-if-empty docker rm --volumes=true

# Remove untagged images
echo "Removing images:" >&2
untagged_images 3 | xargs --no-run-if-empty docker rmi

来源:https://github.com/blueyed/dotfiles/blob/master/usr/bin/docker-cleanup

其他回答

https://github.com/HardySimpson/docker-cleanup

码头工人清理

一个小的一体化外壳,它删除:

一天前没有运行的容器 不属于任何剩余容器的映像

打算作为crontab作业运行

功能

它将删除所有<none>:<none>图像 如果映像有多个repo:标签引用,它将删除所有的repo:标签,除非运行一个容器。实际上这是“docker rmi”的本质。 许多错误信息将显示在屏幕上,你可以决定2>/dev/null或不 从docker-gc中学到一些东西,并修复了它的问题(它不能删除有多个repo:标签的图像)

删除所有docker: docker system prune -a

对于Linux安装,请确保使用sudo。另外,寻找几个月或几周前的图像也很好:

sudo docker ps -a | grep 'weeks ago\|months ago' | \
    awk '{print $1}' | xargs --no-run-if-empty sudo docker rm

我总是使用docker rmi $(docker ps -a -q)删除所有图像。

当docker rmi失败时,可以删除/var/lib/docker/graph目录。

我使用以下的变体:

docker ps -a | grep 'cassandra.*Exited' | cut -d " " -f 1

第一部分列出了所有进程。

第二种选择的是“cassandra”后面跟着“Exited”。

第三个方法是删除图像ID之后的所有测试,这样就得到了一个图像ID列表。

So,

docker rm $(docker ps -a | grep 'cassandra.*Exited' | cut -d " " -f 1)