Docker学习之Image镜像

31次阅读

共计 1994 个字符,预计需要花费 5 分钟才能阅读完成。

我们知道 Image(镜像)是 Docker 的三大组件之一,Docker 运行容器前需要本地存在对应的镜像,如果本地不存在该镜像,Docker 会
从镜像仓库下载该镜像。接下来先看看,怎样去获取镜像。

获取镜像

DockerHub 上有大量的高质量的镜像可以用,这里我们就说一下怎么获取这些镜像。
从 Docker 镜像仓库获取镜像的命令是 docker pull。其命令格式为:

docker pull [选项] [Docker Registry 地址 [: 端口号]/] 仓库名[: 标签]

具体的选项可以通过 docker pull –help 命令看到,这里我们说一下镜像名称的格式。

  • Docker 镜像仓库地址:地址的格式一般是 < 域名 /IP>[: 端口号]。默认地址是 Docker Hub。
  • 仓库名:如之前所说,这里的仓库名是两段式名称,即 < 用户名 >/< 软件名 >。对于 Docker Hub,如果不给出用户名,则默认为 library,也就是官方镜像。

先看一个例子,这里拉取 ubuntu 的一个镜像:

root@huangche-PC:/# docker pull ubuntu:18.04
18.04: Pulling from library/ubuntu
6abc03819f3e: Pull complete 
05731e63f211: Pull complete 
0bd67c50d6be: Pull complete 
Digest: sha256:f08638ec7ddc90065187e7eabdfac3c96e5ff0f6b2f1762cf31a4f49b53000a5
Status: Downloaded newer image for ubuntu:18.04

上面的命令中没有给出 Docker 镜像仓库地址,因此将会从 Docker Hub 获取镜像。而 镜像名称是 ubuntu:18.04,因此将会获取官方镜像 library/ubuntu 仓库中标签为 18.04 的镜像。其中 library 表示组。

从下载过程中可以看到我们之前提及的分层存储的概念,镜像是由多层存储所构成。下载也是一层层的去下载,并非单一文件。下载过程中给出了每一层的 ID 的前 12 位。如:6abc03819f3e: Pull complete , 并且下载结束后,给出该镜像完整的 sha256 的摘要,以确保下载一致性。

运行

通过 docker pull 命令获取到镜像以后,就可以以这个镜像为基础启动并运行一个容器。以上面的 ubuntu:18.04 为例,如果我们打算启动里面的 bash 并且进行交互式操作的话,可以执行下面的命令。

docker run -it --rm \
ubuntu:18.04 \
bash


从上图就可以看出,我们进入了一个以 ubuntu:18.04 镜像为基础的容器环境了(其实也就是进入了一个 ubuntu 系统), 也可以进行 shell 操作了,可以通过 ls -al 查看下:

通过 cat /etc/os-release 来查看下该系统的一些基本信息:


再看下

docker run -it --rm \
ubuntu:18.04 \
bash

这个命令的意思表示啥

  • it:这是两个参数,一个是 -i:交互式操作,一个是 -t 终端。我们这里打算进入 bash 执行一些命令并查看返回结果,因此我们需要交互式终端。
  • rm:这个参数是说容器退出后随之将其删除。默认情况下,为了排障需求,退出的容器并不会立即删除,除非手动 docker rm。我们这里只是随便执行个命令,看看结果,不需要排障和保留结果,因此使用 –rm 可以避免浪费空间。ubuntu:18.04:这是指用 ubuntu:18.04 镜像为基础来启动容器。
  • bash:放在镜像名后的是 命令,这里我们希望有个交互式 Shell,因此用的是 bash。

最后我们通过 exit 退出了这个容器。

列出镜像

在使用 Docker 的过程中,难免需要查看下本地已经存在的可使用的镜像的一些信息,这时候可以使用 docker image ls 命令来进行查看:

列表包含了 仓库名、标签、镜像 ID、创建时间 以及 所占用的空间。
其中仓库名、标签在之前有提到过。镜像 ID 则是镜像的唯一标识,一个镜像可以对应多个 标签。因此,在上面的例子中,我们可以看到 ubuntu:18.04 和 ubuntu:latest 拥有相同的 ID,因为它们对应的是同一个镜像。

删除本地镜像

对于用不到的镜像,可以通过 docker image rm 命令进行删除操作,格式为:

docker image rm [选项] < 镜像 1 > [< 镜像 2 > ...]

其中,< 镜像 > 可以是 镜像短 ID、镜像长 ID、镜像名 或者 镜像摘要。

看到图中列出了三个镜像,接下来对 ngnix 这个镜像进行删除操作:

我们可以用镜像的完整 ID,也称为 长 ID,来删除镜像。使用脚本的时候可能会用长 ID,但是人工输入就太累了,所以更多的时候是用 短 ID 来删除镜像。docker image ls 默认列出的就已经是短 ID 了,一般取前 3 个字符以上,只要足够区分于别的镜像就可以了。

正文完
 0