这个问题与我是否应该关注过量的、未运行的Docker容器有关。
我想知道如何移除旧容器。docker rm 3e552code34a允许你删除一个,但我已经有很多了。Docker rm——help没有提供选择选项(像all一样,或者通过映像名称)。
也许有一个存放这些容器的目录,我可以很容易地手动删除它们?
这个问题与我是否应该关注过量的、未运行的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)