咱们知道Image(镜像)是Docker的三大组件之一,Docker 运行容器前须要本地存在对应的镜像,若是本地不存在该镜像,Docker 会从镜像仓库下载该镜像。接下来先看看,怎样去获取镜像。
DockerHub 上有大量的高质量的镜像能够用,这里咱们就说一下怎么获取这些镜像。
从 Docker 镜像仓库获取镜像的命令是 docker pull 。其命令格式为:docker
docker pull [选项] [Docker Registry 地址[:端口号]/]仓库名[:标签]
具体的选项能够经过 docker pull --help 命令看到,这里咱们说一下镜像名称的格式。shell
先看一个例子,这里拉取ubuntu的一个镜像: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表示组。bash
从下载过程当中能够看到咱们以前说起的分层存储的概念,镜像是由多层存储所构成。下载也是一层层的去下载,并不是单一文件。下载过程当中给出了每一层的 ID 的前 12 位。如:6abc03819f3e: Pull complete ,而且下载结束后,给出该镜像完整的 sha256 的摘要,以确保下载一致性。spa
经过docker pull 命令获取到镜像之后,就能够以这个镜像为基础启动并运行一个容器。以上面的ubuntu:18.04 为例,若是咱们打算启动里面的 bash 而且进行交互式操做的话,能够执行下面的命令。code
docker run -it --rm \ ubuntu:18.04 \ bash
从上图就能够看出,咱们进入了一个以ubuntu:18.04镜像为基础的容器环境了(其实也就是进入了一个ubuntu系统),也能够进行shell操做了,能够经过ls -al查看下:get
经过 cat /etc/os-release来查看下该系统的一些基本信息:域名
再看下it
docker run -it --rm \ ubuntu:18.04 \ bash
这个命令的意思表示啥class
最后咱们经过 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个字符以上,只要足够区分于别的镜像就能够了。