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

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

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


当前回答

下面是一个脚本,用于删除创建时间超过2天的正在运行和已退出的容器:

#!/bin/bash
# This script will kill and remove containers older than 2 days.
#
docker ps -aq > /scripts/containers.txt
today=`date +%Y-%m-%d`
oldate=`date --date="2 day ago" +%Y-%m-%d`
while read p; do
    cont=`docker inspect -f '{{ .Created }}' $p | cut -c 1-10`
    echo " Created date of $p is $cont"
    k=`echo $(( ( $(date -ud $today +'%s') - $(date -ud $cont +'%s'))/60/60/24 ))`
    echo $k
    if [ $k -ge 2 ];
    then
            echo "Killing docker container $p"
            docker kill $p
            echo "Removing docker container $p"
            docker rm $p
    else
            echo "Docker container $p is not one day old, so keeping the container."
    fi
done </scripts/containers.txt

其他回答

首先,在试图删除容器之前停止运行它们

移除正在运行的容器

docker rm $(docker stop -t=1 $(docker ps -q))

你可以用kill代替stop。在我的情况下,我更喜欢停止,因为我倾向于重新运行它们,而不是每次都创建一个新的,所以我试图很好地关闭它们。

注意:试图停止一个容器会给你一个错误:

错误:无法移除正在运行的容器,请先停止它

移除所有容器

docker rm $(docker ps -a -q)

您可以使用一些Docker UI应用程序来删除容器。

抱歉做广告,但我总是用我自己的应用程序做同样的事情。如果您正在寻找一个简单的应用程序来管理Docker映像或容器,您可以尝试一下:https://github.com/alex-agency/AMHub。

这是一个运行在Docker容器内的Docker UI web应用程序。 为了安装它,你只需要调用这个命令:

docker run -d -p 80:80 -p 8000:8000 -e DOCKER=$(which docker) -v /var/run/docker.sock:/docker.sock alexagency/amhub

下面是我的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

使用以下嵌套命令:

$ sudo docker stop $(sudo docker ps -a -q)

该命令将停止所有正在运行的容器。

$ sudo docker rm $(sudo docker ps -a -q)

该命令删除所有容器。

我使用以下的变体:

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)