镜像是Docker三大核心概念中最重要的一个,Dokcer运行容器钱需要本地存在对应的镜像,如果不存在对应的镜像,Doker 会先从默认的镜像仓库下载(如果用户不希望Docker从默认的镜像仓库下载镜像的话,可以使用自定义镜像仓库)。这篇文章将讲解镜像的拉取、查看镜像信息、搜索镜像、删除镜像和镜像的导入导出。
零、拉去镜像
要想拉取镜像,就要用到 pull 命令,该命令的语法为:
docker[image]pull NAME[:TAG]
注:pull 命令中参数 NAME 表示镜像仓库名称,TAG 表示镜像标签(一般表示为版本)
举个例子来看一下pull命令怎么使用。我们从默认的镜像仓库与拉取 Ubuntu 16.04,输入如下命令:
docker pull ubuntu:16.04
执行上面的命令,将会看到如下输出:
注1:如果不显示指定TAG,Docker默认使用latest标签,下载镜像仓库中最新的镜像
注2:latest标签会随着最新版本的变化而变化,例如昨天某镜像的版本是 1.0 ,今天上传了2.0版本的镜像,那么latest标签指的就是2.0这个版本
我们从前面的图中可以看到,在镜像下载过程中出现了4行,这四行代表着镜像文件有4个层,每层的唯一id就是每行开头的那串字符串(例如:35b42117c431)。当不同的镜像存在相同的层时,本地仅存出一份内容,这样就叫少了存储空间。
一般情况下,如果是从官方仓库注册服务器下载镜像文件时是不需要加上仓库注册服务器地址的,但是如果是从非官方仓库注册服务器下载的话,就需要加上注册服务器地址,例如我们要从阿里云下载ubuntu16.04的镜像,那么我们应该这样写命令:
docker pull registry.cn-shanghai.aliyuncs.com/ubuntu:16.04
常用的pull命令参数有如下两个:
参数 | 描述 | 默认值 |
---|---|---|
-a,-all-tags=true|false | 是否获取仓库中所有镜像 | false |
-disable-content-trust | 取消镜像内荣校验 | true |
一、查看镜像信息
查看镜像信息所用到的命令是 images 、 ls 和 inspect 命令。比如要查看当前电脑上存在的镜像,可以这么做:
docker images
或者
docker image ls
执行上面的命令,将会列出当前系统中存在的镜像,如下图
从上图中可以看出如下信息:
- REPOSITORY:镜像来源
- TAG:镜像标签,用于标记来自同一个仓库的不同镜像
- IMAGE ID:镜像ID,镜像的唯一标识
- CREATED:创建时间
- SIZE:镜像大小
注1:镜像ID是很重要的信息,因为它是镜像的唯一标识,我们在操作镜像时需要用到它。一般情况下我们只会输入镜像ID的前N位就可以区分一个镜像了。
注2:镜像的大小只是代表了镜像的逻辑体积大小。由于相同镜像层在本地只会存储一份,因测镜像在物理上占用的空间小于各个镜像的逻辑体积之和。
images 和 ls 命令常用的参数选项如下:
参数 | 描述 | 默认值 |
---|---|---|
-a,–all=true|false | 列出所有镜像文件 | false |
–digests=true|false | 列出镜像数字摘要值 | false |
-f,–filter=[] | 根据过滤而条件列出镜像 | |
–format="" | 控制输出格式 | |
–no-trunc=true|false | 阶段输出结果中过长的字符 | true |
-q,–quiet=true|false | 只输出ID | false |
我们有时候需要获取镜像详细的信息,这时我们可以使用 inspect 命令,语法格式为:
docker inspect [OPTIONS] NAME|ID [NAME|ID...]
例如我们要查看刚才我们拉取的Ubuntu16.04镜像的详细信息,可以这么操作:
docker inspect 13c9
运行上面的命令后,我们会看到镜像的详细信息以json的形式打印出来,如图:
我们不仅可以查看镜像的详细信息,同样我们也可以查看层的详细信息,这时就需要用到 history 命令,语法如下:
docker history [OPTIONS] NAME|ID
例如我们查看Ubuntu16.04镜像层的详细信息:
docker history 13c9
运行命令,将打印出层的详细信息。
二、搜索镜像
我们可以使用 search 命令搜索仓库中的镜像,语法为:
docker search [option] keyword
option 常用的参数如下:
参数 | 描述 | 默认值 |
---|---|---|
-f, --filter | 过滤输出内容 | |
–format | 格式化输出内容 | |
–limit | 限制输出结果个数 | 25 |
–no-trunc | 不揭短输出结果 | fasle |
我们举个例子来看一下,我们要搜索仓库中包含mysql的镜像,代码如下:
docker search mysql
运行上面的命令,将会列出包含mysql关键字的镜像:
三、删除/清除镜像
- 删除镜像
我们删除镜像的时候可以利用 镜像标签 、 镜像ID 来删除镜像。删除镜像的语法为:
docker rmi IMAGE_NAME|IMAGE_ID
例如我们利用镜像标签删除u16.04这个镜像:
docker rmi u16.04
运行上面的命令,u16.04这个镜像将会被删除。
注1:u16.04 这个镜像是我利用ubuntu:16.04 这个镜像通过添加镜像标签创建的
注2:当使用镜像ID删除镜像时,会先删除所有指向该镜像的标签,然后再删除该镜像文件本身
注3:如果存在通过该镜像创建的容器时,镜像文件无法删除。如果要强制删除镜像时,可以使用 -f 参数:
docker rmi -f u16.04
,但是不建议强制删除镜像。
- 清楚镜像
经过一段时间,系统中会存在临时/不再使用的镜像文件,那么我们可以通过 prune 命令清理镜像,语法如下:
docker image [options] prune
option 常用的参数如下:
参数 | 描述 |
---|---|
-a,-all | 删除所有无用镜像 |
-filter | 只删除符合过滤条件的镜像 |
-f,-force | 强制删除镜像 |
四、导入导出镜像
- 导出
如果要将镜像导出可使用 save 命令,语法如下:
docker save image -o file
-o 表示将镜像导出到tar文件,例如我们将 ubuntu:16.04导出到 u1604.tar 文件中:
docker save 13c9 -o u1604.tar
运行上面命令后,ubuntu:16.04就导入到了ub1604.tar文件中:
- 导入
如果要将镜像导出可使用 load 命令,语法如下:
docker load -i file
-i 表示将要导入到docker的镜像tar文件,例如我们将 ub1604.tar导入到docker中:
docker load -i u1604.tar
运行上面命令后,ub1604.tar将被导入到docker中
五、上传镜像
如果是上传到官方仓库,那么需要先注册,然后才可以利用 push 命令上传镜像,语法如下:
docker push NAME[:TAG]|[REGISTRY_HOST[:REGISTRY_PORT]/]
例如我们将ubuntu:16.04上传到官方服务器上:
docker push 13c9
63898662814)]
五、上传镜像
如果是上传到官方仓库,那么需要先注册,然后才可以利用 push 命令上传镜像,语法如下:
docker push NAME[:TAG]|[REGISTRY_HOST[:REGISTRY_PORT]/]
例如我们将ubuntu:16.04上传到官方服务器上:
docker push 13c9