赞
踩
Docker image
本质上是一个 read-only 只读文件, 这个文件包含了文件系统、源码、库文件、依赖、工具等一些运行 application 所必须的文件.
每一层文件系统我们叫做一层 layer,联合文件系统可以对每一层文件系统设置三种权限,只读(readonly)、读写(readwrite)和写出(whiteout-able),但是 docker镜像中每一层文件系统都是只读的。
构建镜像的时候,从一个最基本的操作系统开始,每个构建的操作都相当于做一层的修改,增加了一层文件系统。一层层往上叠加,上层的修改会覆盖底层该位置的可见性,这也很容易理解,就像上层把底层遮住了一样。当你使用的时候,你只会看到一个完全的整体,你不知道里面有几层,也不清楚每一层所做的修改是什么。
镜像相当于我们 Java 或者 C++ 中的类,相当于一个模板,可以很方便的构建出来不同的对象。
镜像生活案例
我们以日常的地板为例,开发商的房子提供给用户的时候一般是做好了地暖,而这些地暖其实是一层一层添加的,最底层的钢筋水泥层,然后添加保温层,采暖管,再铺设水泥层,到最后交付的时候家家户户都是水泥面,这一层一般是不可修改的,最上层用户一般会再铺设商木地板或者地板砖每家每户的选择不一样,相当于我们镜像的容器层。
在部署应用时,通过手工或写一些脚本的方式进行部署。这样部署面临问题就是云端和本地环境一致问题。用户为每个应用打包过程比较繁琐,需要配置和给中修改等操作,非常费劲。
然而, Docker 镜像就是为了解决这个小小的打包功能,突然一夜之间成名。那么,你可能说 Docker 镜像就是个压缩包,是的,你猜对了,它就像一个压缩包文件。它是如何解决 Paas 时代所面临的云端和本地一致性问题?很简单,它是把一个镜像制作成一个完整的操作系统所有文件和对应的目录结构,这样的压缩包是跟你本地和测试环境用的操作系统一摸一样。
docker 最大的贡献就是定义了容器镜像的分层的存储格式, docker 镜像技术的基础是联合文件系统(UnionFS),其文件系统是分层的。这样既可以充分利用共享层,又可以减少存储空间占用。
docker 镜像提供了一种打包应用程序和预配置服务器环境的便捷方式,可以很方便的将其用于个人用途或与其他 Docker 用户公开共享。
docker rmi [OPTIONS] IMAGE [IMAGE...]
docker image rm, docker image remove
#通过image id删除
docker rmi 0c00acac9c27
#通过名字:TAG删除
docker rmi busybox:1.35.0
这里我们需要注意的是,如果有容器引用了该镜像,那么这个镜像不能直接被删除,必须先删除,当然也可以直接带-f
命令强制删除。
docker save [OPTIONS] IMAGE [IMAGE...]
docker image save
关键参数
样例
docker save -o mybusybox1.tar busybox:1.36.0
docker load [OPTIONS]
docker image load
docker load -i mybusybox1.tar
docker history [OPTIONS] IMAGE
docker image history
关键参数
样例
docker history busybox:1.26.0
docker image prune [OPTIONS]
关键参数
样例
#清理不被任何容器使用的无效或悬空镜像
docker image prune
#删除所有容器不使用的镜像
docker image prune -a
使用busybox查看容器启动后的IP,并把该镜像删除掉
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。