如何删除 Docker 镜像、容器和卷?

简介: 【5月更文挑战第11天】

Docker 是一个开源的容器化平台,允许开发者在容器中打包、交付和运行应用程序。容器是一种轻量级、可移植的软件单元,它将应用程序及其依赖项打包在一起,以确保在任何环境中都能一致地运行。

  • 镜像: Docker 镜像是一个只读的文件,包含了运行应用程序所需的一切,包括代码、运行时、库、环境变量和配置文件。镜像是容器的基础。

  • 容器: 容器是 Docker 镜像的运行实例。它是一个独立的、可执行的软件包,包括应用程序和其依赖项。容器提供了隔离和一致性,确保应用在任何地方都以相同的方式运行。

  • 卷: Docker 卷是用于在容器之间共享数据的持久化存储。卷使数据在容器之间保持不变,即使容器被删除,数据仍然存在。

删除 Docker 镜像

使用 docker rmi 命令

要删除 Docker 镜像,我们使用 docker rmi 命令,其基本语法如下:

docker rmi [OPTIONS] IMAGE [IMAGE...]
  • OPTIONS: 可选参数,例如 -f(强制删除)等。
  • IMAGE: 要删除的镜像名称或 ID。

删除单个镜像

要删除单个镜像,只需使用 docker rmi 命令后跟镜像的名称或 ID。

docker rmi my_image

删除多个镜像

删除多个镜像时,可以在命令中列出它们的名称或 ID。

docker rmi image1 image2

强制删除镜像

如果某个镜像正在被使用,Docker 默认不允许删除。但可以使用 -f 参数强制删除。

docker rmi -f my_image

删除带有标签的镜像

当一个镜像有多个标签时,可以通过指定标签来删除特定标签的镜像。

docker rmi my_image:tag1

使用过滤器删除镜像

根据名称删除

通过使用过滤器,我们可以根据名称删除匹配的镜像。

docker rmi $(docker images -q --filter "reference=my_*")

这将删除所有名称以 "my_" 开头的镜像。

根据标签删除

类似地,我们可以使用过滤器根据标签删除匹配的镜像。

docker rmi $(docker images -q --filter "label=my_label")

这将删除所有具有特定标签的镜像。

根据镜像 ID 删除

使用过滤器,我们可以根据镜像 ID 删除特定的镜像。

docker rmi $(docker images -q --filter "id=abc123")

这将删除镜像 ID 为 "abc123" 的镜像。

删除 Docker 容器

使用 docker rm 命令

删除单个容器

要删除单个容器,我们使用 docker rm 命令,其基本语法如下:

docker rm [OPTIONS] CONTAINER [CONTAINER...]
  • OPTIONS: 可选参数,例如 -f(强制删除)等。
  • CONTAINER: 要删除的容器名称或 ID。

删除多个容器

删除多个容器时,可以在命令中列出它们的名称或 ID。

docker rm container1 container2

强制删除容器

如果某个容器正在运行,Docker 默认不允许删除。但可以使用 -f 参数强制删除。

docker rm -f container_name

清理停止的容器

使用 docker container prune 命令

docker container prune 命令可以一次性删除所有停止的容器,确保系统资源得到有效清理。

docker container prune

清理所有停止的容器

有时我们想删除所有停止的容器,可以结合 docker ps -q 命令和 docker rm 命令来实现。

docker rm $(docker ps -aq)

这将删除所有容器,无论它们的状态是运行中还是已停止。

删除 Docker 卷

使用 docker volume rm 命令

删除单个卷

要删除单个卷,我们使用 docker volume rm 命令,其基本语法如下:

docker volume rm VOLUME [VOLUME...]
  • VOLUME: 要删除的卷名称或 ID。

删除多个卷

删除多个卷时,可以在命令中列出它们的名称或 ID。

docker volume rm volume1 volume2

清理未使用的卷

使用 docker volume prune 命令

docker volume prune 命令可以一次性删除所有未被关联到容器的卷。

docker volume prune

清理悬空卷

有时候,由于容器删除不彻底或其他原因,可能会产生悬空的卷。我们可以使用以下命令清理这些悬空卷。

docker volume rm $(docker volume ls -qf dangling=true)

这将删除所有未被容器使用的卷。

删除过程中的注意事项

在删除 Docker 镜像、容器和卷时,一些注意事项包括:

  • 安全删除容器和卷: 确保容器中没有重要数据,可以通过备份或导出数据来确保安全删除。

  • 确保没有依赖项: 在删除镜像、容器或卷之前,确保它们没有被其他容器或服务所依赖。否则,可能会导致不可预知的问题。

  • 备份重要数据: 在删除卷之前,确保将其中重要的数据进行备份,以防止数据丢失。

删除特定应用的容器和镜像

假设我们有一个名为 "myapp" 的应用,我们可以使用以下命令删除与该应用相关的所有容器和镜像:

docker rm $(docker ps -aqf "name=myapp") && docker rmi $(docker images -qf "label=myapp")

清理整个 Docker 环境

如果要清理整个 Docker 环境,可以使用以下命令一次性删除所有容器、镜像和卷:

docker rm -f $(docker ps -aq) && docker rmi -f $(docker images -aq) && docker volume prune -f
目录
相关文章
|
24天前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
184 77
|
6天前
|
搜索推荐 安全 数据安全/隐私保护
7 个最能提高生产力的 Docker 容器
7 个最能提高生产力的 Docker 容器
75 35
|
1月前
|
监控 Docker 容器
在Docker容器中运行打包好的应用程序
在Docker容器中运行打包好的应用程序
|
5天前
|
Ubuntu Linux 开发工具
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
Docker 是一个开源的容器化平台,允许开发者将应用程序及其依赖项打包成标准化单元(容器),确保在任何支持 Docker 的操作系统上一致运行。容器共享主机内核,提供轻量级、高效的执行环境。本文介绍如何在 Ubuntu 上安装 Docker,并通过简单步骤验证安装成功。后续文章将探讨使用 Docker 部署开源项目。优雅草央千澈 源、安装 Docker 包、验证安装 - 适用场景:开发、测试、生产环境 通过以上步骤,您可以在 Ubuntu 系统上成功安装并运行 Docker,为后续的应用部署打下基础。
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
|
1月前
|
Docker 容器
将本地的应用程序打包成Docker镜像
将本地的应用程序打包成Docker镜像
|
11天前
|
存储 Kubernetes 开发者
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
Docker 是一种开源的应用容器引擎,允许开发者将应用程序及其依赖打包成可移植的镜像,并在任何支持 Docker 的平台上运行。其核心概念包括镜像、容器和仓库。镜像是只读的文件系统,容器是镜像的运行实例,仓库用于存储和分发镜像。Kubernetes(k8s)则是容器集群管理系统,提供自动化部署、扩展和维护等功能,支持服务发现、负载均衡、自动伸缩等特性。两者结合使用,可以实现高效的容器化应用管理和运维。Docker 主要用于单主机上的容器管理,而 Kubernetes 则专注于跨多主机的容器编排与调度。尽管 k8s 逐渐减少了对 Docker 作为容器运行时的支持,但 Doc
73 5
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
|
17天前
|
NoSQL PHP MongoDB
docker push推送自己搭建的镜像
本文详细介绍了如何搭建和复盘两个Web安全挑战环境:人力资源管理系统和邮件管理系统。首先,通过Docker搭建MongoDB和PHP环境,模拟人力资源管理系统的漏洞,包括nosql注入和文件写入等。接着,复盘了如何利用这些漏洞获取flag。邮件管理系统部分,通过目录遍历、文件恢复和字符串比较等技术,逐步绕过验证并最终获取flag。文章提供了详细的步骤和代码示例,适合安全研究人员学习和实践。
42 3
docker push推送自己搭建的镜像
|
17天前
|
关系型数据库 应用服务中间件 PHP
实战~如何组织一个多容器项目docker-compose
本文介绍了如何使用Docker搭建Nginx、PHP和MySQL的环境。首先启动Nginx容器并查看IP地址,接着启动Alpine容器并安装curl测试连通性。通过`--link`方式或`docker-compose`配置文件实现服务间的通信。最后展示了Nginx配置文件和PHP代码示例,验证了各服务的正常运行。
43 3
实战~如何组织一个多容器项目docker-compose
|
11天前
|
Unix Linux Docker
CentOS停更沉寂,RHEL巨变限制源代:Docker容器化技术的兴起助力操作系统新格局
操作系统是计算机系统的核心软件,管理和控制硬件与软件资源,为用户和应用程序提供高效、安全的运行环境。Linux作为开源、跨平台的操作系统,具有高度可定制性、稳定性和安全性,广泛应用于服务器、云计算、物联网等领域。其发展得益于庞大的社区支持,多种发行版如Ubuntu、Debian、Fedora等满足不同需求。
39 4
|
21天前
|
Docker 容器