获取镜像
$docker pull NAME[:TAG]
如果不加TAG则表示下载最新的镜像,一个镜像由“名称”+“标签决定”
使用不同镜像仓库服务器情况下,可能会出现镜像重名:
严格的将,镜像的仓库名称中还应该添加仓库地址(即registry,注册服务器)作为前缀,如果使用Docker Hub服务,该前缀可以忽略。
即:$docker pull ubuntu:14.04
相当于$docker pull registry.hub.docker.com/ubuntu:14.04
image
pull子命令:
-a, --all-tags=true|false
:是否获取仓库中的所有镜像,默认为否。
使用镜像:例如利用该镜像创建一个容器,在其中运行bash应用,执行ping localhost:$docker run -it unbuntu[:TAG] bash
root@f46310567509:/# ping localhost
如果提示command not found,则$apt-get update
$apt-get install iputils-ping
详细见:http://blog.csdn.net/silentwolfyh/article/details/52336007
image
image
image
查看镜像信息
docker images [OPTIONS][REPOSITORY[:TAG]]
OPTIONS说明:
-a
:列出本地所有的镜像(含中间映像层,默认情况下,过滤掉中间映像层);—digests
:显示镜像的摘要信息;-f
:显示满足条件的镜像;—format
:指定返回值的模板文件;--no-trunc
:显示完整的镜像信息;-q
:只显示镜像ID。
使用docker images
命令列出镜像image
镜像的仓库:ubuntu的系列镜像由ubuntu仓库保存
标签
镜像ID,镜像的唯一标识
创建的时间,说明镜像最后跟新时间
镜像大小
镜像标签
使用tag命令添加镜像标签,可以发现多了一个myubuntu:latest标签,其id和ubuntu:latest是一样的,其实他们都指向同一个镜像,只是别名不同,标签相当于起到了链接的作用。
image
查看镜像详细信息
使用docker inspect
命令查看详细信息,包括制作者、适应架构、各层的数字摘要等:
image
输出一个json文件
[ { "Id":"sha256:8b72bba4485f1004e8378bc6bc42775f8d4fb851c750c6c0329d3770b3a09086", "RepoTags":[ "myubuntu:latest", "ubuntu:latest" ], "RepoDigests":[ "ubuntu@sha256:2b9285d3e340ae9d4297f83fed6a9563493945935fc787e98cc32a69f5687641" ], "Parent":"", "Comment":"", "Created":"2017-09-13T03:58:50.383839319Z", "Container":"ee87d884293ece0d9fa040a43ffb75097264185f94437a0d1fc2ddfd3c82ca4b", "ContainerConfig":{ "Hostname":"ee87d884293e", "Domainname":"", "User":"", "AttachStdin":false, "AttachStdout":false, "AttachStderr":false, "Tty":false, "OpenStdin":false, "StdinOnce":false, "Env":[ "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin" ], "Cmd":[ "/bin/sh", "-c", "#(nop) ", "CMD ["/bin/bash"]" ], "ArgsEscaped":true, "Image":"sha256:5bf9c8f025cb9bdfec431fbf2a39e1d25117a94ce2b10db01db9630addfc5e37", "Volumes":null, "WorkingDir":"", "Entrypoint":null, "OnBuild":null, "Labels":{ } }, "DockerVersion":"17.06.2-ce", "Author":"", "Config":{ "Hostname":"", "Domainname":"", "User":"", "AttachStdin":false, "AttachStdout":false, "AttachStderr":false, "Tty":false, "OpenStdin":false, "StdinOnce":false, "Env":[ "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin" ], "Cmd":[ "/bin/bash" ], "ArgsEscaped":true, "Image":"sha256:5bf9c8f025cb9bdfec431fbf2a39e1d25117a94ce2b10db01db9630addfc5e37", "Volumes":null, "WorkingDir":"", "Entrypoint":null, "OnBuild":null, "Labels":null }, "Architecture":"amd64", "Os":"linux", "Size":120102168, "VirtualSize":120102168, "GraphDriver":{ "Data":{ "LowerDir":"/var/lib/docker/overlay2/579119ec0ba94ba9c2b510b75228f366c14fc1a29302f29a7c915946f9038c54/diff:/var/lib/docker/overlay2/2286560d99b26f3e25b0cb65f100915b2bf3848ff483b2b46f036a782fe92e87/diff:/var/lib/docker/overlay2/90c4f96886f317dfc958dededefa77f9a648011b7002e42c458b61022e950ab9/diff:/var/lib/docker/overlay2/fba0d170b11c979215b1fe227f86b3499427f1908f3f70dbddde2f94d433ee77/diff", "MergedDir":"/var/lib/docker/overlay2/95395204f6fdd03d04da60ee7d1c1e7ff4bf7e96eb789eca0cdeedf58125aecb/merged", "UpperDir":"/var/lib/docker/overlay2/95395204f6fdd03d04da60ee7d1c1e7ff4bf7e96eb789eca0cdeedf58125aecb/diff", "WorkDir":"/var/lib/docker/overlay2/95395204f6fdd03d04da60ee7d1c1e7ff4bf7e96eb789eca0cdeedf58125aecb/work" }, "Name":"overlay2" }, "RootFS":{ "Type":"layers", "Layers":[ "sha256:8aa4fcad5eeb286fe9696898d988dc85503c6392d1a2bd9023911fb0d6d27081", "sha256:ebf3d6975c708f538b14a5267afd2c4c64e8243d195aa11d878e566a7e64c727", "sha256:a76db6d8fac422acd5fb6c28166c906c202639e4e833cf88c7d4965b806c5437", "sha256:cd1d6655b4e44bb95df75bd2ecde4ad6799dd23337a9dedadf6e0b7f0efdc27e", "sha256:3996d0debc49f9a96c25d4ab7a5c9e824229c09976551b80ab0da70fa993a10d" ] } } ]
可以使用-f
参数来指定获取某一项参数:
image
参考http://www.cnblogs.com/boshen-hzb/p/6376674.html
镜像历史
使用history
命令查看镜像历史。
镜像文件由多个层组成,可以用history命令,显示各层的创建信息。
image
搜寻镜像
使用docker search
命令可以搜索远端仓库中共享的镜像,默认搜索官方仓库总的镜像。用法为docker search TERM,支持的主要参数包括:
--automated=true|false
:仅显示自动创建的镜像,默认为否--no-trunc=true|false
:输出信息不截断显示,默认为否-s, --stars=X
:指定仅显示评价为指定星级以上的镜像,默认为0,即输出所有镜像。
例如,搜索所有自动创建的3星级以上的带 nginx关键字的镜像:image
删除镜像
使用docker rmi
命令可以删除镜像,命令格式为docker rmi IMAGE [IMAGE]
,其中IMAGE可以为标签或ID。
例如,要删除掉myubuntu:latest镜像,可以使用如下命令
image
可以看出,如果一个镜像有多个标签,只会删除多个标签中指定的标签而已,镜像不会受影响。
如果某个镜像只有一个标签时,则要注意,删除标签就会删除镜像。
现在只有一个标签,然后尝试删除镜像:
image
删除失败,因为有容器还在镜像上面运行
可以使用docker ps -a
命令查看本机上的所有容器:
image
可以看出有容器在镜像上运行,所以不能直接删除,当然可以使用命令$docker rmi -f ubuntu:latest
来强制删除,但是不建议这样做,建议先删除容器,然后删除镜像:
我们先使用-f
参数来删除httpd镜像:
image
但是发现镜像依然存在
image
再次使用$docker ps -a
命令来查看容器,发现仍然有容器运行
image
所以并不推荐使用-f
参数来强制删除,下面是正确的步骤,先删除运行在镜像上面的容器,然后再删除镜像。
现在先使用$docker rm CONTAINER_ID
删除容器,有一个错误,
image
可以看出id为a420...的容器还在运行,所以不能删除,使用$docker ps -a
查看删除情况,
状态为未运行的容器已经删除,然而运行状态的并没有删除
所以现在需要先使用$docker stop CONTAINER_ID
停止运行的容器
image
可以看出id为a420...的容器状态已经改变,现在可以删除了
image
可以看出,容器已经被删除了,现在就可以去删除httpd镜像了:
image
使用$docker rmi IMAGE_ID
删除镜像,然后使用$docker images查看删除情况,可以看出httpd镜像已经全部删除完了。
一次性删除所有容器
image
创建镜像
创建镜像的方法主要有三种:
基于已有镜像的容器创建
基于本地模板导入
基于Dockerfile创建
这里主要介绍前两种方法,第三种方法后续学习笔记介绍。
基于已有镜像的容器创建
主要使用docker commit
命令。命令格式为docker commit [OPTIONS] CONTAINER [REPOSITORY [:TAG]]
所基于的容器 创建的镜像的标签
主要的选项包括:
-a, author=""
:作者信息-c, --change=[]
:提交的时候执行Dockerfile命令,包括CMD|ENTRYPOINT|ENV|EXPOSE|LABEL|USER|VOLUME|WORKDIR
等-m, --message=""
:提交消息-p, --pause=true
:提交时暂停容器运行
下面演示怎么根据已有镜像的容器创建一个新的镜像。
首先启动一个镜像,然后进行进行一些操作,例如创建一个test文件,然后退出:$docker run -it ubuntu:latest /bin/bash
root@3548583db1bb:/# touch test
root@3548583db1bb:/# exit
记住容器的ID为3548583db1bb。image
然后使用docker images
命令查看刚才创建的镜像,也可以使用docker ps -a
来查看容器。
接下来使用·docker commit·命令根据容器3548583db1bb来创建一个新的镜像。提交信为:Added a new file
作者信息为:Docker Newbee
源容器:3548583db1bb
被创建的容器的标签:test:0.1
image
使用docker image命令查看刚才创建的test:0.1镜像
基于本地模板导入
用户可以直接从一个操作系统模板文件导入一个镜像文件,主要使用docker import命令。命令格式为docker import [OPTIONS] file |URL| -[REPOSITORY[:TAG]]
OPTIONS说明:
-c:应用docker指令创建镜像文件
-m:提交信息
要直接导入一个镜像,可以使用OpenVZ提供的模板来创建,或者用其他已导出的镜像模板来创建。OPENVZ模板的下载地址为http://openvz.org/Dowload/templates/precreatedimage
存出和载入镜像
用户可以使用docker save和docker load命令来存出和载入镜像。
存出镜像
docker save
:将指定镜像保存成tar归档文件。
语法:docker save [OPTIONS] IMAGE [IMAGE…]
OPTIONS说明:
-o
:输出到文件image
得到了my_ubuntu.tar归档
载入镜像
可以使用docker load
将导出的tar文件再导入到本地文件镜像库,例如从文件my_ubuntu.tar
docker load:从一个在stdin上的tar归档文件中装载镜像
OPTIONS说明:
-i, --input=""
从一个tar归档文件中读入,而不是从stdin中$docker load --input my_ubuntu.tar
或$docker load < my_ubuntu.tar
上传镜像
可以使用docker push
命令上传镜像到仓库,默认上传到Docker Hub官方仓库(需要登录)。
命令格式为:docker push NAME[:TAG] | REGISTRY_HOST[:REGISTRY_PORT] /]NAME [:TAG]
先给需要push的镜像打上标签,因为的我用户名叫kylinxiang,所以改为kylinxiang/push_test:1.0
默认是Push到Docker Hub,所以可以看到最后push到的仓库为docker.io/kylinxiang
image
之后就可以在Docker Hub上面就可以查看Push的镜像
作者:kylinxiang
链接:https://www.jianshu.com/p/4f39ea2dd2b3
共同学习,写下你的评论
评论加载中...
作者其他优质文章