[#]: subject: "Docker Commands Tutorial | Getting Started With Docker In Linux"
[#]: via: "https://ostechnix.com/getting-started-with-docker/"
[#]: author: "sk https://ostechnix.com/author/sk/"
[#]: collector: "lkxed"
[#]: translator: "MCGA"
[#]: reviewer: " "
[#]: publisher: " "
[#]: url: " "

Docker 命令教程 | 在 Linux 中入门 Docker
======

初学者的 Docker 基本命令

这篇详细的 Docker 教程覆盖了核心的 **Docker 命令**,比如,如何创建新容器,运行容器,删除容器等。另外,这篇教程也解释了如何从已有的容器构建你自己的 Docker 镜像,如何移除容器和镜像。言归正传,现在开始 Docker 的基本用法。

### Docker 安装步骤

大多数现代 Linux 操作系统都可以安装 Docker。如果还没安装过 Docker,请参考下面的步骤:

* [在 AlmaLinux,CentOS,Rocky Linux 上安装 Docker Engine 和 Docker Compose][1]
* [如何在 Ubuntu 上安装 Docker 和 Docker Compose][2]

### 什么是 Docker 镜像和 Docker 容器?

在开始 Docker 之前,我先说明一下 Docker 镜像和 Docker 容器是什么。

Docker 镜像是一个描述容器如何运行的的文件,Docker 容器是 Docker 镜像在运行或被终止时的一个阶段。

容器和主机上的其他文件是隔离的。

当我们运行一个 Docker 容器的时候,它会使用一个被隔离出来的文件系统,这个文件系统是由一个 Docker 镜像提供的。Docker 镜像包含了运行应用程序所需要的一切东西 - 所有的依赖,配置,脚本,二进制文件等等。

镜像也包含容器所需要的其他配置项,比如说环境变量,运行的默认命令,以及其他元数据。

### Linux 下的 Docker 入门

下面的所有步骤都已在 Ubuntu 22.04,20.04 以及 18.04 LTS 服务器版本中测试通过。后续小节中提供的步骤对于所有 Linux 平台都是通用的。比如,在基于 RHEL 的系统中(比如 AlmaLinux)可以运行相同的命令。

#### 1. 搜索 Docker 镜像

我们可以从叫做 [Docker hub][3] 的 docker 官方库获得镜像,或者我们也可以制作自己的镜像。

有些人可能不清楚,Docker hub 是一个线上的中心化仓库,所有的 Docker 用户在上面构建,测试,然后保存他们的 Docker 镜像。Docker hub 有数以万计的 Docker 镜像,而且这个数字还在每天增长。

你可以从命令行通过 **“docker search”** 命令搜索任意 Docker 镜像。

比如要搜索基于 **Alpine** Linux 的 docker 镜像,运行:

```
$ sudo docker search alpine
```

**输出结果:**

![Search Docker Images][4]

搜索基于 **Ubuntu** 的镜像,运行:

```
$ sudo docker search ubuntu
```

你还可以搜索其他任意的应用,比如 **Nginx**,像下面这样:

```
$ sudo docker search nginx
```

Docker hub 有各种各样的镜像。你能在 Docker hub 上找到一切已构建好的 Docker 镜像,比如说操作系统,应用,或者多个应用的合体(比如 LAMP 栈)。

如果你找的东西不在上面,你还可以构建一个镜像,然后通过 Docker hub 向其他人开放,或者只是自己用。

#### 2. 下载 Docker 镜像

从终端运行下面的命令可以下载 Ubuntu OS 的 Docker 镜像:

```
$ sudo docker pull ubuntu
```

上面的这个命令会从 Docker hub 下载最新的 Ubuntu 镜像。

**输出结果:**

```
Using default tag: latest
latest: Pulling from library/ubuntu
405f018f9d1d: Pull complete
Digest: sha256:b6b83d3c331794420340093eb706a6f152d9c1fa51b262d9bf34594887c2c7ac
Status: Downloaded newer image for ubuntu:latest
docker.io/library/ubuntu:latest
```

你也可以用下面的命令下载指定版本的 Ubuntu 镜像:

```
$ sudo docker pull ubuntu:20.04
```

Docker 允许我们下载任何镜像,并且在那个镜像上创建容器,这些操作与主机的操作系统无关。

比如要下载 Alpine 系统的镜像,运行:

```
$ sudo docker pull alpine
```

![Download Docker Images][5]

#### 3. 列出 Docker 镜像

所有已下载的 Docker 镜像都保存在 **/var/lib/docker** 路径下。

要查看所有已下载的 Docker 镜像,运行:

```
$ sudo docker images
```

**输出结果:**

```
REPOSITORY   TAG       IMAGE ID       CREATED       SIZE
ubuntu       latest    27941809078c   3 weeks ago   77.8MB
ubuntu       20.04     20fffa419e3a   3 weeks ago   72.8MB
alpine       latest    e66264b98777   5 weeks ago   5.52MB
```

![List Docker Images][6]

从上面可以看出来,我已经下载了三个 Docker 镜像 - **Ubuntu** **lates**,**Ubuntu 20.04** 和 **Alpine Linux**。

现在,我们看一下接下来如何从下载的镜像启动或者运行容器。

#### 4. 运行 Docker 容器

有两种方法我们可以启动一个容器 - 使用 Docker **镜像** **TAG** 或者 **<ruby>镜像 ID<rt>Image ID</rt></ruby>**。

**TAG** 指的是一个特定的镜像快照,**<ruby>镜像 ID<rt>Image ID</rt></ruby>** 是那个镜像对应的唯一识别码。

可以查看下面这个截图:

![Docker Image Tag and ID][7]

从上面的解脱可以看到,<ruby>标签<rt>tags</rt></ruby>是 **latest** 和 **“20.04”**。

* 27941809078c is the IMAGE ID of Ubuntu latest Docker image,
* 27941809078c 是 Ubuntu latest 的 Docker 镜像的<ruby>镜像 ID<rt>IMAGE ID</rt></ruby>,
* 20fffa419e3a is the image id of Ubuntu 20.04 Docker image
* 20fffa419e3a 是 Ubuntu 20.04 的 Docker 镜像的镜像 ID,
* and `e66264b98777` is the image id of Alpine latest Docker image.
* 而  `e66264b98777` 是 Alpine latest 的 Docker 镜像的镜像 ID。

##### 4.1. 使用<ruby>标签<rt>Tag</rt></ruby>运行容器

下载选择好的 Docker 镜像后,运行下面的命令来启动 Docker 容器,并且通过它的<ruby>标签<rt>TAG</rt></ruby>进行连接。

```
$ sudo docker run -t -i ubuntu:latest /bin/bash
```

或者,

```
$ sudo docker run -it ubuntu:latest /bin/bash
```
这里,

* -t:在 Ubuntu 容器内分配一个伪终端。
* -i:通过从容器获取一个便准输入(STDIN),允许我们创建一个可交互的连接。
* ubuntu:latest:标签为“latest”的 Ubuntu docker 镜像。
* /bin/bash:新容器的 BASH shell。这个是可选项。如果你不加 shell 的话,默认的 shell 会被分配给容器。

启动容器后,会自动进入容器的 shell(命令行):

![Run Containers Using Tag][8]

基于最新 Ubuntu 镜像的容器现在已经启动了。所有的新容器都会被赋予一个名字和唯一的 ID。从上面的输出可以看到,那个 Ubuntu 容器的 ID 是 **2f2a5b826762**。一会儿我们会看到从哪找到容器的名字。

现在就可以在容器里面工作了。当你完成容器内的工作后,你可以回到主机操作系统的终端(在我这个例子中,操作系统是 Ubuntu 22.04 LTS)而不需要关掉容器(客户机)。

##### 4.2. 从运行中的容器中分离

使用 **CTRL+P** 然后 **CTRL+Q** 就可以从运行中的容器分离(不需要关闭)。

现在,你就回到了你原来的主机的终端窗口。请注意,容器还在后台运行中,我们并没有关掉它。

##### 4.3. 使用镜像 ID 运行容器

另一种启动容器并且连接进去的方式是通过使用镜像 ID,像下面这样:

```
$ sudo docker run -it 20fffa419e3a /bin/bash
```

这里,

* 20fffa419e3a - 镜像 id

按 **CTRL+P** 然后 **CTRL+Q** 可以从当前容器中分离回到主机系统的终端。我们只是从容器中分离,但是没有让它停止。容器仍然在后台运行中。

##### 4.4. 在分离模式中运行容器

在前面的小结中,我们启动了一个容器并且立刻连接了进去。然后当容器中的工作结束后,我们从容器中分离了出来

你也可以在分离模式(不需要自动连接进去)中启动容器

在后台运行一个容器,输入命令:

```
$ sudo docker run -it -d alpine:latest
```

**输出结果:**

```
d74f2ceb5f3ad2dbddb0b26e372adb14efff91e75e7763418dbd12d1d227129d
```

上面输出结果的前 12 字符代表的是容器的 ID

通过 `docker ps` 命令,你可以验证容器是否在运行:

```
$ sudo docker ps
CONTAINER ID   IMAGE           COMMAND     CREATED         STATUS         PORTS     NAMES
d74f2ceb5f3a   alpine:latest   "/bin/sh"   3 seconds ago   Up 2 seconds             zen_pascal
```

![Run Containers In Background][9]

从上面个的输出结果中可以看到,我们创建了一个 Alpine 容器,但是还没有连接进去。

如果你想连接进去,很简单,运行:

```
$ sudo docker attach d74f2ceb5f3a
```

#### 5. 查看运行中的容器

查看运行中的容器,运行下面的命令:

```
$ sudo docker ps
```

**输出结果:**

```
CONTAINER ID   IMAGE           COMMAND       CREATED          STATUS          PORTS     NAMES
f7e04eed577e   20fffa419e3a    "/bin/bash"   6 minutes ago    Up 6 minutes              brave_mclean
2f2a5b826762   ubuntu:latest   "/bin/bash"   18 minutes ago   Up 18 minutes             hungry_leavitt
```

![View Running Containers][10]

这里,

* f7e04eed577e 是由镜像 “2f2a5b826762” 创建的 Ubuntu 容器的 ID。并且,“brave_mclean”是这个容器的名字。
* 2f2a5b826762 是由镜像 “ubuntu:latest” 创建的 Ubuntu 容器的 ID。并且,“hungry_leavitt” 是这个容器的名字。

当一个新容器被创建后,一个唯一的 ID 和名字会赋给它,这样我们就能通过它的 ID 和名字来连接它。

**注意:** 请注意**容器 ID 和 Docker 镜像 ID 是不同的**。

列出所有可用的(运行或者停止)容器,运行:

```
$ sudo docker ps -a
```

#### 6. 从运行中的容器分离或连接

首先,通过 `docker ps` 命令找到容器的 ID。

```
$ sudo docker ps
```

然后,运行 `docker attach` 命令连接到运行中的容器。

```
$ sudo docker attach <container-id>
```

比如像下面这样,我要连接到 ID 为 “f7e04eed577e” 的容器:

```
$ sudo docker attach f7e04eed577e
```

你也可以通过使用它的名字连接到一个容器。

```
$ sudo docker attach brave_mclean
```

现在你就登录到这个容器了。

想要从容器分离,只要按 **CTRL+P** 然后 **CTRL+Q**。

#### 7. 启动,重启,暂停和终止容器。

你可以使用容器的名字或 ID 来启动,重启,暂停或者终止一个 Docker 容器。

首先,通过 `docker ps -a` 命令找到容器的名字或 ID。

![Find Container ID And Name][11]

现在,通过使用 `docker start` 命令,加上名字或 ID,你可以启动一个容器,像下面这样:

```
$ sudo docker start modest_cray
```

```
$ sudo docker start 10615254bb45
```

用空格隔开,就可以**启动多个容器**,像下面这样:

```
$ sudo docker start 24b5ee8c3d3a 56faac6d20ad d74f2ceb5f3a
```

优雅的重启一个运行中的容器,运行:

```
$ sudo docker start 10615254bb45
```

暂停一个运行中的容器:

```
$ sudo docker pause 10615254bb45
```

把暂停的容器恢复过来:

```
$ sudo docker unpause 10615254bb45
```

直到其它容器都停止前,阻塞一个容器:

```
$ sudo docker wait 10615254bb45
```

我们可以很容易地通过使用它的名字或 ID 来终止一个容器。如果你已经在容器的 shell 里了,只需要运行下面的命令就可以非常简单的终止:

```
# exit
```

你也可以使用下面的命令从 Docker 的主机系统中终止(关闭容器)容器:

```
$ sudo docker stop 10615254bb45
```

用空格隔开,你可以退出多个容器,像下面这样。

```
$ sudo docker stop 35b5ee8c3d3a 10615254bb45
```

在退出容器之后,通过列出所有容器的命令来确保它确实被终止了:

```
$ sudo docker ps
```

#### 8. <ruby>强行关闭<rt>Kill</rt></ruby> Docker 容器

docker stop 命令可以非常优雅的关掉运行中的容器。有时候,你可能卡在一个没有响应的容器,或者你想强制关掉容器。

通过给一个运行中的容器发送 `SIGKILL` 来强行关闭容器,运行:

```
$ sudo docker kill 10615254bb45
```

#### 9. 在关闭容器后自动删除他们

也许你想测试一个容器,然后当你完成在容器中的工作就把它删掉。如果是这样,通过使用 `--rm` 标签在关闭后自动删掉容器:

```
$ sudo docker run -it --rm debian:latest
```

当你从容器中退出,它会自动被删掉。

![Automatically Delete Containers][12]

从上面的结果可以看到,我先创建了一个新的 Debian 容器。当我退出这个容器的时候,它就被自动删掉了。`docker ps -a` 命令的输出结果显示,Debian 容器现在不存在。

#### 10. 给容器命名

如果你再看一下之前命令的输出结果,当你启动一个容器的时候,每个容器都被赋予了一个随机的名字。如果你不命名你的容器,Docker 会自动替你给他们命名。

现在看一下下面的例子:

```
$ sudo docker run -it -d alpine:latest
2af79e97a825c91bf374b4862b9e7c22fc22acd1598005e8bea3439805ec335d
```

```
$ sudo docker run -it -d alpine:latest
80b53b7e661d33696b65c78267fc3f067b6100799c925910db4721963e3fae0a
```

```
$ sudo docker ps
CONTAINER ID   IMAGE           COMMAND     CREATED         STATUS         PORTS     NAMES
80b53b7e661d   alpine:latest   "/bin/sh"   3 seconds ago   Up 2 seconds             bold_margulis
2af79e97a825   alpine:latest   "/bin/sh"   6 seconds ago   Up 5 seconds             recursing_taussig
```

从上面的结果可以看到,尽管我用同一个 docker image 创建了两个容器,它们获得了不同的 ID 和名字。

如果你想给容器赋一个不变的名字,使用 `--name` 标签,像下面这样:

```
$ sudo docker run -it -d --name ostechnix_alpine alpine:latest
```

上面的命令会在分离模式中创建一个叫做 **ostechnix_alpine** 的新容器。

我们看一下当前运行的容器列表:

```
$ sudo docker ps
```
**输出结果:**

```
CONTAINER ID   IMAGE           COMMAND     CREATED         STATUS         PORTS     NAMES
397111fac537   alpine:latest   "/bin/sh"   2 seconds ago   Up 2 seconds             ostechnix_alpine
80b53b7e661d   alpine:latest   "/bin/sh"   7 minutes ago   Up 7 minutes             bold_margulis
2af79e97a825   alpine:latest   "/bin/sh"   7 minutes ago   Up 7 minutes             recursing_taussig
```

![Assign Name To Containers][13]

注意到上面输出结果中的第一个容器的名字了吗?对了,我们给这个容器分配了一个自定义的名字(也就是 `ostechnix_alpine`)。

给容器分配自定义的名字可以给我们带来其他好处。只要看一下容器的名字,我们就能很容易的确定那个容器里面安装了什么。

#### 11. 构建自定义 Docker 镜像

Docker 不仅仅是下载和使用已存在的容器。你也可以创建自己的自定义 docker 镜像。

现在我们开始一个 Ubuntu 容器:

```
$ sudo docker run -it ubuntu:latest
```

现在,你会进入到容器的 shell。

然后,在容器中,你可以安装任何的软件或者做你想做的事情。

比如,我们在容器中安装 “Apache web server**。

```
# apt update
# apt install apache2
```

相似地,在容器中,可以根据自己的需要安装和测试软件。

完成以后,从容器分离(不要退出)回到主机系统的 shell。不要终止或者关闭容器。使用 **CTRL+P** 然后 **CTRL+Q** 从容器中分离,这样不会关闭容器。

在你的 Docker 主机的终端,运行下面的命令来找到容器 ID:

```
$ sudo docker ps
```

最后,创建一个当前运行中的容器的 Docker image,使用命令:

```
$ sudo docker commit 377e6d77ebb5 ostechnix/ubuntu_apache
```

**输出结果**

```
sha256:bc5e5f95ca592a3585fda2c5a40ec30c98e292046ef70390a2c3b7863cc6f7c1
```

这里,

* 377e6d77ebb5 – Ubuntu 容器的 ID。
* ostechnix – 创建容器的用户的名字。
* ubuntu_apache – 用户 ostechnix 创建的 docker image 的名字。

现在我们查看一下新的 Docker 镜像是否被创建了,使用下面的命令:

```
$ sudo docker images
```

**输出结果:**

```
ostechnix/ubuntu_apache
```

![Build Custom Docker Images][14]

从上面给的结果中可以看到,从运行中的容器创建的新 Docker 镜像已经在我们的 Docker 主机系统中了。

现在你就可以从这个新的 Docker 镜像创建行容器了,用之前的命令:

```
$ sudo docker run -it ostechnix/ubuntu_apache
```

#### 12. 移除容器

当你在 Docker 容器中完成所有开发后,如果你不需要他们了,你可以删掉他们。

为此,首先我们需要终止(关闭)运行中的容器。

用这个命令来看一下运行中的容器:

```
$ sudo docker ps
```

**输出结果:**

```
CONTAINER ID   IMAGE           COMMAND   CREATED         STATUS         PORTS     NAMES
377e6d77ebb5   ubuntu:latest   "bash"    7 minutes ago   Up 7 minutes             elegant_beaver
```

通过使用它的 ID 来终止运行中的容器:

```
$ sudo docker stop 377e6d77ebb5
```

现在,使用这个命令删除容器:

```
$ sudo docker rm 377e6d77ebb5
```

同样,如果不再需要所有的容器,关闭并删除它们。

一个一个的删除多个容器会是一项繁琐的工作。所以,我们可以把所有停止的容器一次性删掉,运行:

```
$ sudo docker container prune
```

敲 **Y** 然后回车键,这些容器就被删掉了。

```
WARNING! This will remove all stopped containers.
Are you sure you want to continue? [y/N] y
Deleted Containers:
397111fac5374921b974721ee646b2d5fbae61ca9c6e8b90fbf47952f382a46b
80b53b7e661d33696b65c78267fc3f067b6100799c925910db4721963e3fae0a
[...]
Total reclaimed space: 176B
```

![Delete Containers][15]

这个命令只有在最新版中有效。

使用下面的命令来验证是否所有容器都被删除了:

```
$ sudo docker ps -a
```

如果看不到任何结果,说明所有容器被删掉了。

#### 13. 删除 Docker 镜像

记住,在删除所有镜像之前,首先要删掉所有从那些镜像创建的容器。

当你删掉容器后,你可以删掉你不需要的 Docker 镜像。

列出所有下载的 Docker 镜像:

```
$ sudo docker images
```

**输出结果:**

```
REPOSITORY                TAG       IMAGE ID       CREATED          SIZE
ostechnix/ubuntu_apache   latest    bc5e5f95ca59   14 minutes ago   229MB
debian                    latest    d2780094a226   11 days ago      124MB
ubuntu                    latest    27941809078c   3 weeks ago      77.8MB
ubuntu                    20.04     20fffa419e3a   3 weeks ago      72.8MB
alpine                    latest    e66264b98777   5 weeks ago      5.52MB
```

从上面可以看到,在我们的主机上有 5 个 Docker 镜像。

通过使用镜像 ID 来删掉它们:

```
$ sudo docker rmi ce5aa74a48f1
```

**输出结果:**

```
Untagged: ostechnix/ubuntu_apache:latest
Deleted: sha256:bc5e5f95ca592a3585fda2c5a40ec30c98e292046ef70390a2c3b7863cc6f7c1
Deleted: sha256:a8e4797160a2b2d33d8bd1bd67e008260c022b3a53fbcc198b2b74d9eae5961d
```

同样,删除其他所有 Docker 镜像。

删掉所有未运行的容器,所有镜像,构建的缓存,所有网络,运行:

```
$ sudo docker system prune -a
```

使用这个命令的时候要注意,它会删掉所有没有使用的容器,网络,镜像(<ruby>挂起<rt>dangling</rt></ruby>和<ruby>未使用<rt>unreferenced</rt></ruby>)

![Delete Everything In Docker][16]

默认情况下,即使当前没有容器在使用<ruby>磁盘容量<rt>volumes</rt></ruby>,为防止重要数据被删除,<ruby>磁盘容量<rt>volumes</rt></ruby>也不会被删除

如果你想删掉所有东西,包括分配的容量,使用 `--volumes` 标签。

```
$ sudo docker system prune -a --volumes
```

### Docker 问题汇总

Docker 不会允许你删除 Docker 镜像,如果这些镜像正在被运行或停止的容器使用。

比如,当我尝试从一个以前的 Ubuntu 服务器上删除 ID 为 **b72889fa879c** 的 Docker 镜像。我会得到下面的错误:

```
Error response from daemon: conflict: unable to delete b72889fa879c (must be forced) - image is being used by stopped container dde4dd285377
```

这是因为你想删除的 Docker 镜像正在被另一个容器使用。

所以,我们先查看一下运行中的容器,使用命令:

```
$ sudo docker ps
```

**输出结果:**

![Show running docker containers][17]

噢,没有运行中的容器。

我们在看一下所有的容器(运行和停止的),用这个命令:

```
$ sudo docker ps -a
```

**输出结果:**

![Show running and stopped docker containers][18]

可以看到,仍然有停止的容器在使用其中一个 Docker 镜像。所以,我们先把所有容器删掉。

**比如:**

```
$ sudo docker rm 12e892156219
```

类似地,向上面那样,用对应容器的 ID 将他们都删除。

当把所有容器删掉后,移除掉 Docker 镜像。

**比如:**

```
$ sudo docker rmi b72889fa879c
```

就这么简单。现在确认是否还有其他 Docker 镜像在主机上,使用命令:

```
$ sudo docker images
```

你现在应该不再有任何 docker 镜像了。

### 总结

在这篇全面的 Docker 入门教程中,我们解释了 Docker 的基本操作,比如创建,运行,搜索,删除容器,还有从 Docker 镜像构建你自己的容器。同时,我们也解释了如何在不需要 Docker 容器和镜像的时候删除它们。

希望你现在对 **Docker 的使用** 有一个基本的了解

更多细节,请参考这篇教程最下面的官方资源链接,或者在下面的评论区进行评论。

**相关资料:**

* [Docker 官网][19]
* [Docker 文档][20]

--------------------------------------------------------------------------------

via: https://ostechnix.com/getting-started-with-docker/

作者:[sk][a]
选题:[lkxed][b]
译者:[MCGA](https://github.com/Yufei-Yan)
校对:[校对者ID](https://github.com/校对者ID)

本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出

[a]: https://ostechnix.com/author/sk/
[b]: https://github.com/lkxed
[1]: https://ostechnix.com/install-docker-almalinux-centos-rocky-linux/
[2]: https://ostechnix.com/install-docker-ubuntu/
[3]: https://hub.docker.com/
[4]: https://ostechnix.com/wp-content/uploads/2022/07/Search-Docker-Images.png
[5]: https://ostechnix.com/wp-content/uploads/2022/07/Download-Docker-Images.png
[6]: https://ostechnix.com/wp-content/uploads/2022/07/List-Docker-Images.png
[7]: https://ostechnix.com/wp-content/uploads/2022/07/Docker-Image-Tag-and-ID.png
[8]: https://ostechnix.com/wp-content/uploads/2022/07/Run-Containers-Using-Tag-1.png
[9]: https://ostechnix.com/wp-content/uploads/2022/07/Run-Containers-In-Background-1.png
[10]: https://ostechnix.com/wp-content/uploads/2022/07/View-Running-Containers.png
[11]: https://ostechnix.com/wp-content/uploads/2022/07/Find-Container-ID-And-Name.png
[12]: https://ostechnix.com/wp-content/uploads/2022/07/Automatically-Delete-Containers.png
[13]: https://ostechnix.com/wp-content/uploads/2022/07/Assign-Name-To-Containers.png
[14]: https://ostechnix.com/wp-content/uploads/2022/07/Build-Custom-Docker-Images.png
[15]: https://ostechnix.com/wp-content/uploads/2022/07/Delete-Containers.png
[16]: https://ostechnix.com/wp-content/uploads/2022/07/Delete-Everything-In-Docker.png
[17]: https://ostechnix.com/wp-content/uploads/2016/04/sk@sk-_005-1-1.jpg
[18]: https://ostechnix.com/wp-content/uploads/2016/04/sk@sk-_006-1.jpg
[19]: https://www.docker.com/
[20]: https://docs.docker.com/