docker容器的加载原理和数据卷挂载(一)
nanshan 2024-10-10 07:16 27 浏览 0 评论
docker镜像原理
在说原理之前,先来说下这个联合文件系统,设计确实挺好轻量级,高性能的文件系统
- 联合文件系统(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)
- 数据卷的定义:它是一个提供一个或多个容器使用的特殊目录,它绕过了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:后面的章节还要继续学习容器数据卷的一些内容
相关推荐
- 服务器数据恢复—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...
- 服务器数据恢复—服务器磁盘阵列常见故障表现&解决方案
-
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...
你 发表评论:
欢迎- 一周热门
-
-
爱折腾的特斯拉车主必看!手把手教你TESLAMATE的备份和恢复
-
如何在安装前及安装后修改黑群晖的Mac地址和Sn系列号
-
[常用工具] OpenCV_contrib库在windows下编译使用指南
-
WindowsServer2022|配置NTP服务器的命令
-
Ubuntu系统Daphne + Nginx + supervisor部署Django项目
-
WIN11 安装配置 linux 子系统 Ubuntu 图形界面 桌面系统
-
解决Linux终端中“-bash: nano: command not found”问题
-
NBA 2K25虚拟内存不足/爆内存/内存占用100% 一文速解
-
Linux 中的文件描述符是什么?(linux 打开文件表 文件描述符)
-
K3s禁用Service Load Balancer,解决获取浏览器IP不正确问题
-
- 最近发表
-
- 服务器数据恢复—Raid5数据灾难不用愁,Raid5数据恢复原理了解下
- 服务器数据恢复—多次异常断电导致服务器raid不可用的数据恢复
- 服务器数据恢复-V7000存储更换磁盘数据同步失败的数据恢复案例
- 「服务器数据恢复」重装系统导致XFS文件系统分区丢失的数据恢复
- 服务器数据恢复-ESXi虚拟机被误删的数据恢复案例
- 「服务器数据恢复」Raid5阵列两块硬盘亮黄灯掉线的数据恢复案例
- 服务器数据恢复—基于oracle数据库的SAP数据恢复案例
- 「服务器虚拟化数据恢复」Xen Server环境下数据库数据恢复案例
- 服务器数据恢复—RAID故障导致oracle无法启动的数据恢复案例
- 服务器数据恢复—服务器磁盘阵列常见故障表现&解决方案
- 标签列表
-
- linux 查询端口号 (58)
- docker映射容器目录到宿主机 (66)
- 杀端口 (60)
- yum更换阿里源 (62)
- internet explorer 增强的安全配置已启用 (65)
- linux自动挂载 (56)
- 禁用selinux (55)
- sysv-rc-conf (69)
- ubuntu防火墙状态查看 (64)
- windows server 2022激活密钥 (56)
- 无法与服务器建立安全连接是什么意思 (74)
- 443/80端口被占用怎么解决 (56)
- ping无法访问目标主机怎么解决 (58)
- fdatasync (59)
- 405 not allowed (56)
- 免备案虚拟主机zxhost (55)
- linux根据pid查看进程 (60)
- dhcp工具 (62)
- mysql 1045 (57)
- 宝塔远程工具 (56)
- ssh服务器拒绝了密码 请再试一次 (56)
- ubuntu卸载docker (56)
- linux查看nginx状态 (63)
- tomcat 乱码 (76)
- 2008r2激活序列号 (65)