百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

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

nanshan 2024-10-10 07:16 27 浏览 0 评论

docker镜像原理

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

2 . docker镜像加载原理

Docker的镜像实际上由一层一层的文件系统组成,这种层级的文件系统UnionFs

Bootfs(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)

  1. 数据卷的定义:它是一个提供一个或多个容器使用的特殊目录,它绕过了UFS,可以在容器之间共享和重用,对数据卷的修改会立马生效,容器删除也会默认存在
  2. 数据卷的作用:就是解决数据持久化的问题
  3. 挂载方式一
  • 方式一:直接使用 命令挂载 -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:后面的章节还要继续学习容器数据卷的一些内容

相关推荐

服务器数据恢复—Raid5数据灾难不用愁,Raid5数据恢复原理了解下

Raid5数据恢复算法原理:分布式奇偶校验的独立磁盘结构(被称之为raid5)的数据恢复有一个“奇偶校验”的概念。可以简单的理解为二进制运算中的“异或运算”,通常使用的标识是xor。运算规则:若二者值...

服务器数据恢复—多次异常断电导致服务器raid不可用的数据恢复

服务器数据恢复环境&故障:由于机房多次断电导致一台服务器中raid阵列信息丢失。该阵列中存放的是文档,上层安装的是Windowsserver操作系统,没有配置ups。因为服务器异常断电重启后,rai...

服务器数据恢复-V7000存储更换磁盘数据同步失败的数据恢复案例

服务器数据恢复环境:P740+AIX+Sybase+V7000存储,存储阵列柜上共12块SAS机械硬盘(其中一块为热备盘)。服务器故障:存储阵列柜中有磁盘出现故障,工作人员发现后更换磁盘,新更换的磁盘...

「服务器数据恢复」重装系统导致XFS文件系统分区丢失的数据恢复

服务器数据恢复环境:DellPowerVault系列磁盘柜;用RAID卡创建的一组RAID5;分配一个LUN。服务器故障:在Linux系统层面对LUN进行分区,划分sdc1和sdc2两个分区。将sd...

服务器数据恢复-ESXi虚拟机被误删的数据恢复案例

服务器数据恢复环境:一台服务器安装的ESXi虚拟化系统,该虚拟化系统连接了多个LUN,其中一个LUN上运行了数台虚拟机,虚拟机安装WindowsServer操作系统。服务器故障&分析:管理员因误操作...

「服务器数据恢复」Raid5阵列两块硬盘亮黄灯掉线的数据恢复案例

服务器数据恢复环境:HPStorageWorks某型号存储;虚拟化平台为vmwareexsi;10块磁盘组成raid5(有1块热备盘)。服务器故障:raid5阵列中两块硬盘指示灯变黄掉线,无法读取...

服务器数据恢复—基于oracle数据库的SAP数据恢复案例

服务器存储数据恢复环境:某品牌服务器存储中有一组由6块SAS硬盘组建的RAID5阵列,其中有1块硬盘作为热备盘使用。上层划分若干lun,存放Oracle数据库数据。服务器存储故障&分析:该RAID5阵...

「服务器虚拟化数据恢复」Xen Server环境下数据库数据恢复案例

服务器虚拟化数据恢复环境:Dell某型号服务器;数块STAT硬盘通过raid卡组建的RAID10;XenServer服务器虚拟化系统;故障虚拟机操作系统:WindowsServer,部署Web服务...

服务器数据恢复—RAID故障导致oracle无法启动的数据恢复案例

服务器数据恢复环境:某品牌服务器中有一组由4块SAS磁盘做的RAID5磁盘阵列。该服务器操作系统为windowsserver,运行了一个单节点Oracle,数据存储为文件系统,无归档。该oracle...

服务器数据恢复—服务器磁盘阵列常见故障表现&amp;解决方案

RAID(磁盘阵列)是一种将多块物理硬盘整合成一个虚拟存储的技术,raid模块相当于一个存储管理的中间层,上层接收并执行操作系统及文件系统的数据读写指令,下层管理数据在各个物理硬盘上的存储及读写。相对...

「服务器数据恢复」IBM某型号服务器RAID5磁盘阵列数据恢复案例

服务器数据恢复环境:IBM某型号服务器;5块SAS硬盘组成RAID5磁盘阵列;存储划分为1个LUN和3个分区:第一个分区存放windowsserver系统,第二个分区存放SQLServer数据库,...

服务器数据恢复—Zfs文件系统下误删除文件如何恢复数据?

服务器故障:一台zfs文件系统服务器,管理员误操作删除服务器上的数据。服务器数据恢复过程:1、将故障服务器所有磁盘编号后取出,硬件工程师检测所有硬盘后没有发现有磁盘存在硬件故障。以只读方式将全部磁盘做...

服务器数据恢复—Linux+raid5服务器数据恢复案例

服务器数据恢复环境:某品牌linux操作系统服务器,服务器中有4块SAS接口硬盘组建一组raid5阵列。服务器中存放的数据有数据库、办公文档、代码文件等。服务器故障&检测:服务器在运行过程中突然瘫痪,...

服务器数据恢复—Sql Server数据库数据恢复案例

服务器数据恢复环境:一台安装windowsserver操作系统的服务器。一组由8块硬盘组建的RAID5,划分LUN供这台服务器使用。在windows服务器内装有SqlServer数据库。存储空间LU...

服务器数据恢复—阿里云ECS网站服务器数据恢复案例

云服务器数据恢复环境:阿里云ECS网站服务器,linux操作系统+mysql数据库。云服务器故障:在执行数据库版本更新测试时,在生产库误执行了本来应该在测试库执行的sql脚本,导致生产库部分表被tru...

取消回复欢迎 发表评论: