Docker 镜像和容器的区别详解
最近学习docker,被docker 的镜像和容器搞的晕头转向,索性上网查找相关资料并整理下彻底的理解这块内容,有需要的小伙伴可以看下,少走点弯路。
docker的镜像和容器的区别
一、docker镜像
要理解docker镜像和docker容器之间的区别,确实不容易。
假设linux内核是第0层,那么无论怎么运行docker,它都是运行于内核层之上的。这个docker镜像,是一个只读的镜像,位于第1层,它不能被修改或不能保存状态。
一个docker镜像可以构建于另一个docker镜像之上,这种层叠关系可以是多层的。第1层的镜像层我们称之为基础镜像(base image),其他层的镜像(除了最顶层)我们称之为父层镜像(parent image)。这些镜像继承了他们的父层镜像的所有属性和设置,并在dockerfile中添加了自己的配置。
docker镜像通过镜像id进行识别。镜像id是一个64字符的十六进制的字符串。但是当我们运行镜像时,通常我们不会使用镜像id来引用镜像,而是使用镜像名来引用。要列出本地所有有效的镜像,可以使用命令
# docker images
镜像可以发布为不同的版本,这种机制我们称之为标签(tag)。
如上图所示,neo4j镜像有两个版本:lastest版本和2.1.5版本。
可以使用pull命令加上指定的标签:
# docker pull ubuntu:14.04
# docker pull ubuntu:12.04
二、docker容器
docker容器可以使用命令创建:
# docker run imagename
它会在所有的镜像层之上增加一个可写层。这个可写层有运行在cpu上的进程,而且有两个不同的状态:运行态(running)和退出态(exited)。这就是docker容器。当我们使用docker run启动容器,docker容器就进入运行态,当我们停止docker容器时,它就进入退出态。
当我们有一个正在运行的docker容器时,从运行态到停止态,我们对它所做的一切变更都会永久地写到容器的文件系统中。要切记,对容器的变更是写入到容器的文件系统的,而不是写入到docker镜像中的。
我们可以用同一个镜像启动多个docker容器,这些容器启动后都是活动的,彼此还是相互隔离的。我们对其中一个容器所做的变更只会局限于那个容器本身。
如果对容器的底层镜像进行修改,那么当前正在运行的容器是不受影响的,不会发生自动更新现象。
如果想更新容器到其镜像的新版本,那么必须当心,确保我们是以正确的方式构建了数据结构,否则我们可能会导致损失容器中所有数据的后果。
64字符的十六进制的字符串来定义容器id,它是容器的唯一标识符。容器之间的交互是依靠容器id识别的,由于容器id的字符太长,我们通常只需键入容器id的前4个字符即可。当然,我们还可以使用容器名,但显然用4字符的容器id更为简便。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
上一篇: 前端常用的正则表达式(代码实例)
推荐阅读
-
详解C#用new和override来实现抽象类的重写区别
-
详解Python中__str__和__repr__方法的区别
-
C#中Property和Attribute的区别实例详解
-
详解HTML5中div和section以及article的区别
-
Android MotionEvent中getX()和getRawX()的区别实例详解
-
详解利用nginx和docker实现一个简易的负载均衡
-
关于Sequelize连接查询时inlude中model和association的区别详解
-
详解docker下的Mysql镜像的使用方法
-
详解MySQL中DROP,TRUNCATE 和DELETE的区别实现mysql从零开始
-
Android中dip、dp、sp、pt和px的区别详解