docker 批量垃圾清理

简介: 1.清理不使用的容器docker下查看所有容器状态;[root@Ieat1 ace]# docker ps -aCONTAINER ID IMAGE ...

1.清理不使用的容器

docker下查看所有容器状态;

[root@Ieat1 ace]# docker ps -a
CONTAINER ID        IMAGE                                                   COMMAND                  CREATED             STATUS                      PORTS                                                                                                                                                                                                                                                                                                                                                                            NAMES
5bdec325d135        rancher/scheduler:v0.8.3                                "/.r/r /rancher-en..."   9 minutes ago       Up 9 minutes                                                                                                                                                                                                                                                                                                                                                                                                 r-scheduler-scheduler-1-f76d0a08
71123182fa05        ad2daff1ff5b                                            "/bin/sh -c '#(nop..."   11 minutes ago      Created                                                                                                                                                                                                                                                                                                                                                                                                      jovial_shannon
dddc87acc76f        5b67f2e10f0a                                            "/bin/sh -c '#(nop..."   11 minutes ago      Created                                                                                                                                                                                                                                                                                                                                                                                                      nervous_sinoussi
fe9de3dd24e6        da359ca34301                                            "/bin/sh -c '#(nop..."   11 minutes ago      Created                                                                                                                                                                                                                                                                                                                                                                                                      clever_nightingale
7afd9d696b0a        16d61edb6b05                                            "/bin/sh -c 'bash ..."   11 minutes ago      Exited (0) 11 minutes ago                                                                                                                                                                                                                                                                                                                                                                                    loving_euclid
7a8b85b75259        40531ed606d2                                            "/bin/sh -c 'bash ..."   11 minutes ago      Exited (0) 11 minutes ago

会发现有除了有Up 正常状态的容器之外还有Created状态的容器和Exited状态的容器

    1. Up 正常状态
    1. Created,表示容器已经创建,但是没有启动,它和stop不同,stop通常都是手动或者外部操作容器停止的,而created有可能是手动创建但是没有成功启动,created状态的容器不占用内存和CPU资源,但是看着很不爽啊,需要清理掉
    1. Exited 可能是我们手动停止的

我们在确认是不需要了的容器之后清理Created状态的容器

[root@Ieat1 ace]# docker rm `docker ps -a|grep Created |awk '{print $1}'`
71123182fa05
dddc87acc76f
fe9de3dd24e6
f6da8d32f75d
435f49e2ebf3
044691253c83
6bbac38816e4
aa4a3f41d0a0

要删除全部容器的话(慎用),不会删除运行中的容器

docker rm $(docker ps -aq)

2.清理不需要的镜像

查看所有镜像

[root@Ieat1 ace]# docker images -a
REPOSITORY                                       TAG                 IMAGE ID            CREATED             SIZE
<none>                                           <none>              ad2daff1ff5b        22 minutes ago      230 MB
<none>                                           <none>              5b67f2e10f0a        22 minutes ago      230 MB
<none>                                           <none>              da359ca34301        22 minutes ago      230 MB
rawmind/alpine-zk                                3.4.10-0            d4bca3df91dc        9 months ago        158 MB
docker.elastic.co/elasticsearch/elasticsearch    5.5.1               74ef44f69db6        12 months ago       544 MB
rawmind/rancher-zk                               3.4.9               36ddfd137679        14 months ago       33.7 MB

我们一般定义image,都是使用Dockerfile,我们随时可能修改这个文件,然后重新使用docker build -t name . 命令来构建一个新的image。这种情况下,如果我们使用了和之前一样的镜像名来命名,那么docker会把这个名字赋给新的镜像,以前的镜像并不会被删除,但是此时它的名字被新的镜像剥夺了,就成为了一个无名(untagged)镜像,也就是<none>:<none>出现的原因。
这个none镜像会占用磁盘空间,所以我们必须删除它。

可以使用如下的一个命令:

[root@Ieat1 ace]# docker rmi $(docker images -f "dangling=true" -q)
Deleted: sha256:ad2daff1ff5bb5567bb6fa5f5a717ccfe97fb03f801528ea2b86370112777c64
Deleted: sha256:5b67f2e10f0a60d1fd92ae1842a2acd130bdf52649973b7d6fc160ff5f990897
Deleted: sha256:da359ca34301bf6eabbaf5150b5868e508f0a55b147d3f7f7a0cc4991f0c009c
Deleted: sha256:a3cc78a32eaed87d8c521183dfbd0672e2334bbd734edce048f13a6a47a575cf
Deleted: sha256:4f1024022f5974a9f0436e03ab59107089afaa05848a4c5e8958b716ff39b957
Deleted: sha256:b35d31df021a83eb143030b9a231b3273f2274465097c4e4716032509b79e816

删除untagged images,也就是那些id为<None>的image的话也可以如下命令

docker rmi $(docker images | grep "^<none>" | awk "{print $3}")

要删除全部image的话(慎用),不会删除被容器使用中的镜像

docker rmi $(docker images -q)

3.清理不需要的数据卷

查看没有容器关联的数据卷

docker volume ls -qf dangling=true

注意:清理数据卷请确认数据卷确实不需要后谨慎操作!

清理命令

docker volume rm $(docker volume ls -qf dangling=true)
目录
相关文章
|
16天前
|
负载均衡 网络协议 开发者
掌握 Docker 网络:构建复杂的容器通信
在 Docker 容器化环境中,容器间的通信至关重要。本文详细介绍了 Docker 网络的基本概念和类型,包括桥接网络、宿主网络、覆盖网络和 Macvlan 网络等,并提供了创建、管理和配置自定义网络的实用命令。通过掌握这些知识,开发者可以构建更健壮和灵活的容器化应用,提高应用的可扩展性和安全性。
|
14天前
|
Linux iOS开发 Docker
Docker:容器化技术的领航者 —— 从基础到实践的全面解析
在云计算与微服务架构日益盛行的今天,Docker作为容器化技术的佼佼者,正引领着一场软件开发与部署的革命。它不仅极大地提升了应用部署的灵活性与效率,还为持续集成/持续部署(CI/CD)提供了强有力的支撑。
192 69
|
1天前
|
Kubernetes Cloud Native 持续交付
云原生之旅:Docker容器化与Kubernetes集群管理
【9月更文挑战第33天】在数字化转型的浪潮中,云原生技术如同一艘航船,带领企业乘风破浪。本篇文章将作为你的航海指南,从Docker容器化的基础讲起,直至Kubernetes集群的高级管理,我们将一起探索云原生的奥秘。你将学习到如何封装应用、实现环境隔离,以及如何在Kubernetes集群中部署、监控和扩展你的服务。让我们启航,驶向灵活、可伸缩的云原生未来。
|
14天前
|
运维 Cloud Native Docker
云原生技术入门:Docker容器化实战
【9月更文挑战第20天】本文将引导你走进云原生技术的世界,通过Docker容器化技术的实战演练,深入理解其背后的原理和应用。我们将一起探索如何在云平台上利用Docker简化部署、扩展和管理应用程序的过程,并揭示这一技术如何改变现代软件的开发和运维模式。
|
9天前
|
Cloud Native 持续交付 Docker
云原生技术入门与实践:Docker容器化部署示例
【9月更文挑战第25天】在数字化转型的浪潮下,云原生技术成为推动企业创新的重要力量。本文旨在通过浅显易懂的语言,为初学者揭示云原生技术的核心概念及其应用价值。我们将以Docker容器为例,逐步引导读者了解如何将应用程序容器化,并在云端高效运行。这不仅是对技术趋势的跟随,更是对资源利用和开发效率提升的探索。
29 4
|
7天前
|
Kubernetes Linux 开发者
深入探索Docker容器化技术的奥秘
深入探索Docker容器化技术的奥秘
16 1
|
10天前
|
存储 Docker 容器
Docker中容器间的通信方式有哪些13
Docker中容器间的通信方式有哪些13
14 4
|
16天前
|
运维 Ubuntu Linux
深入理解并实践Docker容器化技术
深入理解并实践Docker容器化技术
43 6
|
5天前
|
网络协议 安全 开发者
掌握 Docker 网络:构建复杂的容器通信
在 Docker 容器化环境中,容器间的通信至关重要。本文详细介绍了 Docker 网络的基础知识,包括网络驱动、端口映射和命名等核心概念,并深入探讨了 Bridge、Host、Overlay 和 Macvlan 四种网络类型的特点及应用场景。此外,还提供了创建、连接、查看和删除自定义网络的命令示例,以及高级网络配置方法,如网络命名空间、DNS 解析和安全通信配置,帮助开发者构建更健壮的容器化应用。
|
6天前
|
Cloud Native 持续交付 Docker
深入解析Docker容器化技术及其在生产环境中的应用
深入解析Docker容器化技术及其在生产环境中的应用
10 0
下一篇
无影云桌面