这个问题与我是否应该关注过量的、未运行的Docker容器有关。
我想知道如何移除旧容器。docker rm 3e552code34a允许你删除一个,但我已经有很多了。Docker rm——help没有提供选择选项(像all一样,或者通过映像名称)。
也许有一个存放这些容器的目录,我可以很容易地手动删除它们?
这个问题与我是否应该关注过量的、未运行的Docker容器有关。
我想知道如何移除旧容器。docker rm 3e552code34a允许你删除一个,但我已经有很多了。Docker rm——help没有提供选择选项(像all一样,或者通过映像名称)。
也许有一个存放这些容器的目录,我可以很容易地手动删除它们?
当前回答
新方法: Spotify /docker-gc发挥了作用。
docker run --rm -v /var/run/docker.sock:/var/run/docker.sock -v /etc:/etc spotify/docker-gc
超过一小时前离开的集装箱被移除。 删除之后不属于任何剩余容器的图像
它支持环境设置
强制删除具有多个标记的图像
FORCE_IMAGE_REMOVAL=1
强制删除容器
FORCE_CONTAINER_REMOVAL=1
从垃圾收集中排除最近退出的容器和图像
GRACE_PERIOD_SECONDS=86400
此设置还可以防止删除小于GRACE_PERIOD_SECONDS秒前创建的映像。
排练
DRY_RUN=1
清理孤立的容器卷 CLEAN_UP_VOLUMES = 1
参考:docker-gc
老办法:
删除旧的、未运行的容器
docker ps -a -q -f status=exited | xargs --no-run-if-empty docker rm
OR
docker rm $(docker ps -a -q)
删除与未运行的docker容器关联的所有映像
docker images -q | xargs --no-run-if-empty docker rmi
为docker 1.10版本清理孤立的docker卷。X及以上
docker volume ls -qf dangling=true | xargs -r docker volume rm
基于时间段
docker ps -a | grep "weeks ago" | awk "{print $1}" | xargs --no-run-if-empty docker rm
docker ps -a | grep "days ago" | awk "{print $1}" | xargs --no-run-if-empty docker rm
docker ps -a | grep "hours ago" | awk "{print $1}" | xargs --no-run-if-empty docker rm
其他回答
在Ubuntu 14.04 (Trusty Tahr)上:
$ for CON in `docker ps -qa`; do docker rm $CON ; done
这只是一个普通的Bash命令,所以它应该适用于每个Bash兼容的终端。
另一种方法,我从Guillaume J. Charmes那里得到的(出处请注明出处)
docker rm `docker ps --no-trunc -aq`
将以优雅的方式移除所有容器。
由Bartosz Bilicki为Windows编写:
FOR /f "tokens=*" %i IN ('docker ps -a -q') DO docker rm %i
美国小妞PowerShell:
docker rm @(docker ps -aq)
Docker 1.13(2016年第四季度)的更新,归功于VonC(稍后在本帖子中):
docker系统修剪将删除所有未使用的数据(即,按顺序:容器停止,卷没有容器和图像没有容器)。
请参阅PR 26108和commit 86de7c0,它们引入了一些新命令,以帮助方便地可视化Docker守护进程数据在磁盘上占用了多少空间,并允许轻松清理“不需要的”多余空间。
docker system prune
WARNING! This will remove:
- all stopped containers
- all volumes not used by at least one container
- all images without at least one container associated to them
Are you sure you want to continue? [y/N] y
移除所有容器:
sudo docker ps -a | grep -v CONTAINER | awk '{print $1}' | xargs --no-run-if-empty sudo docker rm -f
解释:
sudo docker ps -a
返回一个容器列表。
awk '{print $1}'
获取容器ID的第一列。
grep -v CONTAINER
删除标题。
最后一个管道将id安全地发送到sudo docker rm -f。
我使用以下的变体:
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)
下面是我的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