百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

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

nanshan 2024-11-04 13:04 24 浏览 0 评论

Docker 容器旨在提供一个自给自足的环境,其中包含执行软件所需的所有库和配置。

在本指南中,您将学习如何通过删除 Docker 镜像、容器、卷和网络来组织 Docker 环境

前提准备

  • 运行 Docker 的 Linux 系统
  • 访问终端/命令行(在 Ubuntu 上为Ctrl + Alt + T,在 CentOS 上为Alt + F2
  • 具有sudo 权限的用户帐户

如何删除 Docker 容器

容器创建了一个可以执行进程的特定环境。许多容器在开发生命周期中被创建、测试和废弃。

因此,重要的是要知道如何找到不需要的容器并删除它们。

停止容器

  1. 首先,使用以下命令列出所有 Docker 容器:
docker container ls -a

输出显示所有正在运行的容器、它们的 ID、名称、图像、状态和其他参数的列表。

您还可以仅通过数字 ID 生成所有容器的列表,运行以下命令:

docker container ls -aq 
  1. 停止特定容器,请输入以下内容:
docker container stop [container_id]

替换[container_id]为列表中容器的数字 ID。

您可以在同一命令中输入多个容器 ID。

停止所有容器,请输入:

docker container stop $(docker container ls -aq)

这会强制 Docker 使用所有容器 ID 的列表作为stop命令的目标。

注意:如果您以sudo用户身份登录,请确保在停止所有容器时sudo在两个docker命令前添加前缀( sudo docker container stop $(sudo docker container ls -aq))。

删除停止的容器

删除已停止的容器,请使用以下命令:

docker container rm [container_id]

像以前一样,这将删除具有您指定 ID 的容器。

删除所有停止的容器

删除所有停止容器

docker container rm $(docker container ls -aq)

删除所有 Docker 容器

要清除 Docker 并从头开始,请输入命令:

docker container stop $(docker container ls -aq) && docker system prune -af --volumes

这会指示 Docker 停止括号中列出的容器。

在括号内,您指示 Docker 生成所有容器及其数字 ID 的列表。然后,信息被传递回container stop命令并停止所有容器。

&&属性指示 Docker 删除所有停止的容器和卷。

-af表示这应适用于所有容器 ( a),无需确认 ( f)。

移除带有过滤器的容器

您还可以指定删除所有与指定标签不匹配的对象。

为此,请使用以下命令:

docker container prune --filter="label!=maintainer=Jeremy"

此命令告诉 Docker删除所有未标有“ jeremy ”维护者标签的容器。该 != 命令是一个逻辑符号,表示“不等于”。

label 命令分解 :

  • label=<key>
  • label=<key>=<value>
  • label!=<key>
  • label!=<key>=<value>

将这些术语与标签结合使用可以让您深入控制在 Docker 中删除资产。

如何删除 Docker 镜像

Docker 镜像是文件,其中包括用于在容器内运行代码的多个层。

图像在开发过程中可能会经历多次迭代。旧的和过时的图像会使您的系统变得混乱,占用存储空间并使搜索变得更加麻烦。

  1. 删除 Docker 镜像,首先列出您系统上的所有镜像:
docker image ls

输出显示本地可用的 Docker 映像,如下所示。

  1. 记下IMAGE ID – 这是用于删除图像的标识符。
  2. 然后,删除不需要的图像:
docker image rm [image_id1] [image_id2]

[image_id1][image_id2]为您从第一个命令中提取的图像 ID。您可以输入单个图像 ID,也可以输入多个 ID 以进行删除。

系统可能会以错误消息响应您的请求,说明存在冲突且无法删除存储库引用。这表明容器正在使用该图像。您需要先移除容器,然后才能移除图像。

使用过滤器删除 Docker 镜像

在发布时,唯一支持的过滤器是 untillabel。尽管如此,这些都是用于管理 Docker 资源的强大工具。

使用 until 过滤器删除指定时间内的所有资源。

输入以下内容:

docker image prune -a --filter "until=24h"

这将删除-a过去 24 小时内创建的所有 ( ) 图像。该命令可用于容器、图像和过滤器。确保指定要删除的资产。

until命令接受 Unix 时间戳、日期格式的时间戳或根据机器时间计算的时间量(30m、4h、2h25m)。

使用该 label 命令删除标签定义的资产。

输入以下内容:

docker image prune --filter="label=old"

将删除所有标记为“旧”的docker 图像

过滤也可用于定义标签的特定值。

例如,如果一个容器标有“maintainer”键,并且“maintainer”的值是“bill”或“jeremy”,您可以键入:

docker container prune --filter="label=maintainer=bill"

然后 Docker 删除所有标签为“maintainer”且值为“bill”的容器。

如何删除 Docker 卷

它有助于以可供多个容器访问的方式在容器外存储和组织数据。

  1. 使用以下命令生成所有可用 Docker 卷的列表:
docker volume ls

记下 您要删除的VOLUME NAME

2.然后输入:

docker volume rm VolumeName

确保替换*VolumeName*为您使用上一个命令生成的实际名称。

如果该卷正被现有容器使用,系统将响应错误。这意味着需要先移除容器。

如何删除 Docker 网络

Docker 网络允许不同的容器相互自由通信,同时还阻止来自网络外部的流量。这通常是通过 Docker 桥接网络完成的。

prune命令删除所有未使用的网络。

删除单个网络

1.使用以下命令显示所有现有 Docker 网络的列表

docker network ls
  1. 记下网络 ID – 这是用于删除特定网络的标识符。然后,输入:
docker network rm [networkID]

替换[networkID]为您从第一个命令中捕获的 ID。

您可能会收到一条错误消息,指出网络具有活动端点。这意味着网络当前正在被容器使用。您需要先删除正在使用网络的容器,然后才能删除网络。

删除所有未使用的 Docker 对象

prune命令会自动删除与容器无关的所有资源。这是一种清理未使用的镜像、容器、卷和网络的简化方法。

在终端窗口中,输入以下内容:

docker system prune

可以包括其他标志:

  • -a 包括停止的容器和未使用的图像
  • -f 绕过确认对话框
  • --volumes 删除所有未使用的卷

此外,您可以指定要删除的单一类型的对象,而不是整个环境:

docker container prune``docker image prune``docker volume prune``docker network prune

运行docker system prune -a 会删除未使用的和悬空的图像。容器中使用的图像,无论是当前运行的还是退出的,都不会受到影响。

列出所有 Docker 资源

输入以下命令以显示资源:

docker container ls``docker image ls``docker volume ls``docker network ls``docker info

上面列出了容器的数量、镜像和有关 Docker 安装的信息。这些命令可以帮助您定位和识别要保留或要删除的资源。

还可以添加以下标志:

  • -a 显示所有资源(包括已停止的资源)
  • -q--quiet(仅显示数字 ID)

结论

在本指南中,您学习了删除 Docker 镜像、容器、卷和网络的最常用命令

喜欢的朋友记得给个关注~

相关推荐

服务器数据恢复—Raid5数据灾难不用愁,Raid5数据恢复原理了解下

Raid5数据恢复算法原理:分布式奇偶校验的独立磁盘结构(被称之为raid5)的数据恢复有一个“奇偶校验”的概念。可以简单的理解为二进制运算中的“异或运算”,通常使用的标识是xor。运算规则:若二者值...

服务器数据恢复—多次异常断电导致服务器raid不可用的数据恢复

服务器数据恢复环境&故障:由于机房多次断电导致一台服务器中raid阵列信息丢失。该阵列中存放的是文档,上层安装的是Windowsserver操作系统,没有配置ups。因为服务器异常断电重启后,rai...

服务器数据恢复-V7000存储更换磁盘数据同步失败的数据恢复案例

服务器数据恢复环境:P740+AIX+Sybase+V7000存储,存储阵列柜上共12块SAS机械硬盘(其中一块为热备盘)。服务器故障:存储阵列柜中有磁盘出现故障,工作人员发现后更换磁盘,新更换的磁盘...

「服务器数据恢复」重装系统导致XFS文件系统分区丢失的数据恢复

服务器数据恢复环境:DellPowerVault系列磁盘柜;用RAID卡创建的一组RAID5;分配一个LUN。服务器故障:在Linux系统层面对LUN进行分区,划分sdc1和sdc2两个分区。将sd...

服务器数据恢复-ESXi虚拟机被误删的数据恢复案例

服务器数据恢复环境:一台服务器安装的ESXi虚拟化系统,该虚拟化系统连接了多个LUN,其中一个LUN上运行了数台虚拟机,虚拟机安装WindowsServer操作系统。服务器故障&分析:管理员因误操作...

「服务器数据恢复」Raid5阵列两块硬盘亮黄灯掉线的数据恢复案例

服务器数据恢复环境:HPStorageWorks某型号存储;虚拟化平台为vmwareexsi;10块磁盘组成raid5(有1块热备盘)。服务器故障:raid5阵列中两块硬盘指示灯变黄掉线,无法读取...

服务器数据恢复—基于oracle数据库的SAP数据恢复案例

服务器存储数据恢复环境:某品牌服务器存储中有一组由6块SAS硬盘组建的RAID5阵列,其中有1块硬盘作为热备盘使用。上层划分若干lun,存放Oracle数据库数据。服务器存储故障&分析:该RAID5阵...

「服务器虚拟化数据恢复」Xen Server环境下数据库数据恢复案例

服务器虚拟化数据恢复环境:Dell某型号服务器;数块STAT硬盘通过raid卡组建的RAID10;XenServer服务器虚拟化系统;故障虚拟机操作系统:WindowsServer,部署Web服务...

服务器数据恢复—RAID故障导致oracle无法启动的数据恢复案例

服务器数据恢复环境:某品牌服务器中有一组由4块SAS磁盘做的RAID5磁盘阵列。该服务器操作系统为windowsserver,运行了一个单节点Oracle,数据存储为文件系统,无归档。该oracle...

服务器数据恢复—服务器磁盘阵列常见故障表现&amp;解决方案

RAID(磁盘阵列)是一种将多块物理硬盘整合成一个虚拟存储的技术,raid模块相当于一个存储管理的中间层,上层接收并执行操作系统及文件系统的数据读写指令,下层管理数据在各个物理硬盘上的存储及读写。相对...

「服务器数据恢复」IBM某型号服务器RAID5磁盘阵列数据恢复案例

服务器数据恢复环境:IBM某型号服务器;5块SAS硬盘组成RAID5磁盘阵列;存储划分为1个LUN和3个分区:第一个分区存放windowsserver系统,第二个分区存放SQLServer数据库,...

服务器数据恢复—Zfs文件系统下误删除文件如何恢复数据?

服务器故障:一台zfs文件系统服务器,管理员误操作删除服务器上的数据。服务器数据恢复过程:1、将故障服务器所有磁盘编号后取出,硬件工程师检测所有硬盘后没有发现有磁盘存在硬件故障。以只读方式将全部磁盘做...

服务器数据恢复—Linux+raid5服务器数据恢复案例

服务器数据恢复环境:某品牌linux操作系统服务器,服务器中有4块SAS接口硬盘组建一组raid5阵列。服务器中存放的数据有数据库、办公文档、代码文件等。服务器故障&检测:服务器在运行过程中突然瘫痪,...

服务器数据恢复—Sql Server数据库数据恢复案例

服务器数据恢复环境:一台安装windowsserver操作系统的服务器。一组由8块硬盘组建的RAID5,划分LUN供这台服务器使用。在windows服务器内装有SqlServer数据库。存储空间LU...

服务器数据恢复—阿里云ECS网站服务器数据恢复案例

云服务器数据恢复环境:阿里云ECS网站服务器,linux操作系统+mysql数据库。云服务器故障:在执行数据库版本更新测试时,在生产库误执行了本来应该在测试库执行的sql脚本,导致生产库部分表被tru...

取消回复欢迎 发表评论: