这个问题与我是否应该关注过量的、未运行的Docker容器有关。
我想知道如何移除旧容器。docker rm 3e552code34a允许你删除一个,但我已经有很多了。Docker rm——help没有提供选择选项(像all一样,或者通过映像名称)。
也许有一个存放这些容器的目录,我可以很容易地手动删除它们?
这个问题与我是否应该关注过量的、未运行的Docker容器有关。
我想知道如何移除旧容器。docker rm 3e552code34a允许你删除一个,但我已经有很多了。Docker rm——help没有提供选择选项(像all一样,或者通过映像名称)。
也许有一个存放这些容器的目录,我可以很容易地手动删除它们?
当前回答
Use:
docker rm -f $(docker ps -a -q)
它强制停止并删除本地存在的所有容器。
其他回答
从Docker 1.13开始。x你可以使用Docker容器修剪:
docker container prune
这将删除所有停止的容器,并且应该在所有平台上以相同的方式工作。
还有一个Docker系统修剪:
docker system prune
它将在一个命令中清理所有未使用的容器、网络、映像(悬空和未引用),以及可选的卷。
对于较旧的Docker版本,您可以将Docker命令与其他Unix命令串在一起以获得所需的内容。下面是一个关于如何清理几个星期前的旧容器的例子:
$ docker ps --filter "status=exited" | grep 'weeks ago' | awk '{print $1}' | xargs --no-run-if-empty docker rm
为了表示感谢,这个例子来自https://twitter.com/jpetazzo/status/347431091415703552。
另一种方法,我从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
因此,我个人建议将此作为映像和容器的部署脚本的一部分,只保留最近的n个容器和映像。我用与git标签相同的版本控制模式标记Docker映像,并且总是用“latest”标记最新的Docker映像。这意味着在没有清理任何东西的情况下,我的Docker映像最终看起来像这样:
REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE
some_repo/some_image 0.0.5 8f1a7c7ba93c 23 hours ago 925.4 MB
some_repo/some_image latest 8f1a7c7ba93c 23 hours ago 925.4 MB
some_repo/some_image 0.0.4 0beabfa514ea 45 hours ago 925.4 MB
some_repo/some_image 0.0.3 54302cd10bf2 6 days ago 978.5 MB
some_repo/some_image 0.0.2 0078b30f3d9a 7 days ago 978.5 MB
some_repo/some_image 0.0.1 sdfgdf0f3d9a 8 days ago 938.5 MB
现在,当然我不想让我所有的图像(或容器)在我所有的生产盒上永久保存。我只需要最后的3或4个回滚来去掉其他的东西。尤尼克斯的尾巴是你最好的朋友。由于docker images和docker ps都是按日期排序的,我们可以使用tail选择除前三个之外的所有图像并删除它们:
docker rmi $(docker images -q | tail -n +4)
将其与部署脚本一起运行(或在本地运行),以始终保留足够的映像,以便能够轻松地回滚,而不会占用太多空间或将旧映像弄得乱七八糟。
就我个人而言,我只在我的生产盒上保留一个容器,但如果你想要更多的容器,你可以对容器做同样的事情:
docker rm $(docker ps -aq | tail -n +4)
最后,在我的简化示例中,我们一次只处理一个存储库,但是如果您有更多的存储库,您可以使用相同的思想来变得更复杂一些。假设我只想保留some_repo/some_image中的最后三张图像。我只需要混合grep和awk就可以了:
docker rmi $(docker images -a | grep 'some_repo/some_image' | awk '{print $3}' | tail -n +4)
同样,同样的想法也适用于容器,但到这里你已经明白了,所以我就不举例子了。
我使用以下的变体:
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)
移除所有容器:
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。