龙空技术网

docker容器的加载原理和数据卷挂载(一)

石老师小跟班 147

前言:

如今看官们对“centos挂载内存”大体比较关切,同学们都需要学习一些“centos挂载内存”的相关知识。那么小编在网上汇集了一些对于“centos挂载内存””的相关内容,希望同学们能喜欢,兄弟们快快来了解一下吧!

docker镜像原理

在说原理之前,先来说下这个联合文件系统,设计确实挺好轻量级,高性能的文件系统
联合文件系统(UnionFs)它是一种分层,轻量级并且高性能的文件系统,它支持对文件系统的修改作为一次提交来一层层的叠加,但同时以可以将不同的目录挂载到同一个虚拟文件下文件联合系统就是docker镜像的基础,镜像可以通过分层集成,制作各种具体的应用镜像

2 . docker镜像加载原理

Docker的镜像实际上由一层一层的文件系统组成,这种层级的文件系统UnionFsBootfs(boot-file system)主要包含bootloader和kernel,bootloader主要是引导加载kernel,Linux刚启动时会加载bootfs文件系统,在Docker镜像的最底层是bootfs,这一层与我们典型的Linux/unix系统是一样的,包含boot加载器和内核,当boot加载完成之后整个内核就能在内存中了,此时内存的使用权已由bootfs转交给内核,此时系统也会卸载bootfs。Rootfs(root-file system),在bootfs之上,包含的就是典型Linux系统中的/dev、/proc、/bin、/etc等标准目录和文件,rootfs就是各种不同操作系统的发行版,比如Ubuntu,Centos等等。

3.特点

共享资源:多个镜像是从相同的父镜像构建的docker镜像是只读的,我们所有操作都是在原来的上一层操作的,所以说只有最外层可写的docker commit提交自己的镜像

#docker commit 提交容器成为一个新的副本#参数Options:  -a, --author string    Author (e.g., "John Hannibal Smith <hannibal@a-team.com>") #作者  -c, --change list      Apply Dockerfile instruction to the created image  #改变的内容  -m, --message string   Commit message #提交信息  -p, --pause            Pause container during commit (default true)  #完整命令:  docker commit -m="提交的信息" -a="作者" 容器id 目标镜像名[:tag]
容器数据卷(Volume)数据卷的定义:它是一个提供一个或多个容器使用的特殊目录,它绕过了UFS,可以在容器之间共享和重用,对数据卷的修改会立马生效,容器删除也会默认存在数据卷的作用:就是解决数据持久化的问题挂载方式一方式一:直接使用 命令挂载 -v
docker run -it -v 主机目录:容器目录 -p 主机端口:容器端口 镜像id /bin/bash#我这里使用的windows系统,所以跟服务器上路径不太一样#案例:把centos系统里的/home目录挂载到D:\wsl_www目录下#命令如下docker run --name centos -it -v /mnt/d/wsl_www/home:/home centos /bin/bash#/mnt/d/wsl_www/home这个路径,我解释一下:由于我是基于windows10中子系统安装的docker,所以docker把window下的文件都映射到了/mnt中,所以我这样就可以设置了!#使用docker inspect 容器id
#测试#场景一: 进入到容器里的/home目录下,创建文件,修改内容,我这边会在windows主机下对应该的目录下d:/wsl_www/home跟着变化#场景二:你可以在windows主机上对应的目录里改变数据,容器里对应的目录下也会跟着变化,这里不截图了
如果:我要把容器删除呢?这window主机下的对应目录下的文件还有吗?答案: 是还会保存的,见图

下图是我宿主机里的,数据还在

小案例:安装MySQL,挂载数据卷到主机

#命令1. docker pull mysql:5.7.16  #下载mysql版本5.7.16
#命令二:运行mysql并挂载数据到宿主机的目录中,#注意mysql的配置目录 /etc/mysql下#mysql中的数据目录 /var/lib/mysql#mysql中的日志文件在 /var/log/mysql#运行并挂载命令docker run --name mysql5.7 -v /mnt/d/wsl_www/mysql5.7/conf:/etc/mysql \-v /mnt/d/wsl_www/mysql5.7/data:/var/lib/mysql \-v /mnt/d/wsl_www/mysql5.7/log:/var/log/mysql  -p 3306:3306 \-e MYSQL_ROOT_PASSWORD=123456 \-d mysql:5.7 #参数说明#1.我由于是在windows中子系统wsl运行docker,所以主机目录是/mnt开头的#-v 主机目录:容器里的目录#-p 主机端口:容器端口#-e 设置环境变量 MYSQL_ROOT_PASSWORD 设置root密码# -d 后台运行
问题1:
我这里在主机里看不到映射过去的文件,原因是我的d盘不知在什么时候nmount了,使用df -h并没有查看到 d盘信息,  解决办法如下:在wsl子系统里执行mount命令,使d盘挂载到/mnt/d下#命令如下:#d盘挂载到/mnt/d命令sudo mount -t drvfs D: /mnt/d#卸载命令sudo umount /mnt/d
问题2:
我使用mysql5.7是运行不启来的,报错信息是:Could not set file permission for ca.pem#解决办法#这个解决办法是在github上找到的,说是这个mysql5.7.16是没有这个问题的,  这是出现在win10子系统里的问题,如果使用linux是不会出现的
问题3:
安装成功后,我使用navicat链接docker里的mysql,链接时间比较久,  有知道的小伙伴可以给个解决办法吗?
ps:在windows子系统上运行,确实问题比较多,有能力的小伙伴还是用linux吧,省心ps:后面的章节还要继续学习容器数据卷的一些内容

标签: #centos挂载内存