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)
目录
相关文章
|
17天前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
158 77
|
25天前
|
监控 Docker 容器
在Docker容器中运行打包好的应用程序
在Docker容器中运行打包好的应用程序
|
4天前
|
Unix Linux Docker
CentOS停更沉寂,RHEL巨变限制源代:Docker容器化技术的兴起助力操作系统新格局
操作系统是计算机系统的核心软件,管理和控制硬件与软件资源,为用户和应用程序提供高效、安全的运行环境。Linux作为开源、跨平台的操作系统,具有高度可定制性、稳定性和安全性,广泛应用于服务器、云计算、物联网等领域。其发展得益于庞大的社区支持,多种发行版如Ubuntu、Debian、Fedora等满足不同需求。
19 4
|
19天前
|
数据建模 应用服务中间件 nginx
docker替换宿主与容器的映射端口和文件路径
通过正确配置 Docker 的端口和文件路径映射,可以有效地管理容器化应用程序,确保其高效运行和数据持久性。在生产环境中,动态替换映射配置有助于灵活应对各种需求变化。以上方法和步骤提供了一种可靠且易于操作的方案,帮助您轻松管理 Docker 容器的端口和路径映射。
62 3
|
26天前
|
存储 缓存 监控
Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
本文介绍了Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
67 7
|
26天前
|
存储 Prometheus 监控
Docker容器内进行应用调试与故障排除的方法与技巧,包括使用日志、进入容器检查、利用监控工具及检查配置等,旨在帮助用户有效应对应用部署中的挑战,确保应用稳定运行
本文深入探讨了在Docker容器内进行应用调试与故障排除的方法与技巧,包括使用日志、进入容器检查、利用监控工具及检查配置等,旨在帮助用户有效应对应用部署中的挑战,确保应用稳定运行。
32 5
|
26天前
|
开发框架 安全 开发者
Docker 是一种容器化技术,支持开发者将应用及其依赖打包成容器,在不同平台运行而无需修改。
Docker 是一种容器化技术,支持开发者将应用及其依赖打包成容器,在不同平台运行而无需修改。本文探讨了 Docker 在多平台应用构建与部署中的作用,包括环境一致性、依赖管理、快速构建等优势,以及部署流程和注意事项,展示了 Docker 如何简化开发与部署过程,提高效率和可移植性。
55 4
|
26天前
|
负载均衡 网络协议 算法
Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式
本文探讨了Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式,以及软件负载均衡器、云服务负载均衡、容器编排工具等实现手段,强调两者结合的重要性及面临挑战的应对措施。
60 3
|
26天前
|
存储 安全 数据安全/隐私保护
Docker 容器化应用管理更加高效,但数据安全和业务连续性成为关键。
在数字化时代,Docker 容器化应用管理更加高效,但数据安全和业务连续性成为关键。本文探讨了 Docker 应用的备份与恢复策略,涵盖备份的重要性、内容、方法及常见工具,制定备份策略,恢复流程及注意事项,并通过案例分析和未来趋势展望,强调备份与恢复在保障应用安全中的重要性。
32 2
|
26天前
|
存储 安全 数据中心
Docker 容器凭借轻量级和高效的特性,成为应用部署的重要工具
Docker 容器凭借轻量级和高效的特性,成为应用部署的重要工具。本文探讨了 Docker 如何通过 Namespace 和 Cgroups 实现 CPU、内存、网络和存储资源的隔离,提高系统安全性和资源利用率,以及面临的挑战和应对策略。
43 1

热门文章

最新文章