龙空技术网

每天五分钟玩转-Docker镜像、容器数据卷、编写DockerFile

程序员北边 64

前言:

此时看官们对“docker commit 数据持久化”大约比较讲究,小伙伴们都想要学习一些“docker commit 数据持久化”的相关资讯。那么小编也在网摘上网罗了一些对于“docker commit 数据持久化””的相关资讯,希望看官们能喜欢,小伙伴们一起来了解一下吧!

一、Docker镜像镜像是什么?

镜像是一种轻量级、可执行的独立软件包,用来打包软件运行环境和基于运行环境开发的软件,它包含运行某个软件所需的所有内容,包括代码、运行时、库、环境变量和配置文件

(1)UnionFS(联合文件系统)

UnionFS(联合文件系统):Union文件系统是一种分层、轻量级并且高性能的文件系统,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下,Union文件系统是Dokcer镜像的基础。镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的镜像。

特性:一次同时加载多个文件系统,但从外面看起来,只能看到一个文件系统,联合加载会把各层文件系统加载起来,这样最终的文件系统会包含所有的底层文件和目录

(2)Docker镜像加载原理

docker的镜像实际上是由一层一层的文件系统构成,这种层级的文件系统UnionFS。

主要包含bootloader和kernel,bootloader主要是引导加载kernel,Linux刚启动时会加载bootfs文件系统,在Docker镜像的最底层是bootfs。这一层与我们典型的linux/unix系统是一样的,包含boot加载器内核。当boot加载完之后整个内核就都在内存中了,此时内存的使用权已经由bootfs交给内核了,此时系统也会卸载bootfs

新镜像是从 base 镜像一层一层叠加生成的。每安装一个软件,就在现有镜像的基础上增加一层。

查看分层命令:

docker image inspect redis:latest

**分层特点 **

启动镜像的时候,一个新的可写层会加载到镜像的顶部。这一层通常称为“容器层”, 之下是“镜像层”。容器层可以读写,容器所有发生文件变更写都发生在这一层。镜像层read-only,只允许读取。

commit镜像

docker commit -m=“描述信息” -d=“作者” 容器id 目标镜像名:[tag]

启动一个默认的tomcat(webapps没有文件)

拷贝基本的文件到webapps

提交镜像

docker commit -a="yky" -m="add webapps from webapps.dist for the new tomcat" 75413cb39056 tomcatyky:1.0  
二、容器数据卷1、什么是容器数据卷将运用与运行的环境打包形成容器运行 ,运行可以伴随着容器,但是我们对数据的要求希望是持久化的,容器之间希望有可能共享数据Docker容器产生的数据,如果不通过docker commit生成新的镜像,使得数据作为镜像的一部分保存下来,那么当容器删除后,数据自然也就没有了。为了能保存数据在docker中我们使用卷。容器间数据共享

2、使用数据卷方式一:直接使用挂载命令 -v

docker run -it -v 主机目录:容器内目录
具名挂载匿名挂载
#匿名挂载docker run -d -p --name nginx -v /etc/nginx nginx# 查看所有的volume的情况docker volume ls#匿名挂载的样子 -v时只写了容器内的地址没有容器外的地址local      4dc39817723131876b9a375bc7775922136362996bceb4aaebc559e38e3f1b98#通过 -v 卷名:容器内名称#查看某个卷

所有docker的卷没有指定目录的情况下都在cd /var/lib/docker/volumes/xxxxxx/_data

通过具名挂载可方便地找到我们的卷,大多数情况下使用的都是具名挂载

如何确定是具名挂载匿名挂载还是指定地址挂载

-v 容器路径  #匿名挂载-v 卷名:容器类路径 #具名挂载-v /宿主机路径:容器内路径 #指定路径挂载
设置权限
-v 容器内路径:ro rw 改变读写权限
初识DockerFile

DockerFile就是用来构建docker镜像文件的构建文件(命令脚本)

通过脚本可以生成镜像

dockerFile脚本

FROM centosVOLUME ["volume01","volume02"]CMD echo "----end----"CMD /bin/bash
执行脚本

查看构建的镜像

查看卷挂载的路径测试刚刚创建的文件是否挂载出去了

docker inspact 容器id
数据卷容器

多个MySQL同步数据

mysql03挂载到,MySQL02的目录下

docker run -d -p 3306:3306 -e MYSQL_ROOT_PASSWORD=密码 --name mysql03 --volume-from mysql02 镜像名id 

容器之间配置信息的传递,数据卷容器的生命周期一直持续到没有容器使用为止,

但是一旦持久化到了本地,这个时候本地数据是不会删除的

DockerFile编写一个dockerFile文件docker build构建成为一个镜像docker run 运行镜像docker push发布镜像(dockerHUB、阿里云镜像仓库)DockerFile构建过程

1、基础知识

每个保留字(指令)必须大写

执行从上到下的顺序

表示注释

每一个指令都会创建一个新的镜像,并提交

2、dockerfile是面向开发的

DockerFile:构建文件,定义了一切步骤,源代码

DockeImage:通过DockerFile构建的镜像,最终发布和运行的产品

Docker容器:容器就是镜像运行起来提供服务器

自己动手创建一个镜像

一般镜像都是由基础镜像过来的:FROM scratch,然后配置其他信息

#构建的镜像基于哪个基础镜像FROM scratch  #为基础惊醒天机内容ADD centos-8-x86_64.tar.xz /#设置镜像层LABEL org.label-schema.schema-version="1.0" \    org.label-schema.name="CentOS Base Image" \    org.label-schema.vendor="CentOS" \    org.label-schema.license="GPLv2" \    org.label-schema.build-date="20200611"#设置容器的启动命令CMD ["/bin/bash"]

标签: #docker commit 数据持久化