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

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

nanshan 2024-10-10 07:16 34 浏览 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:后面的章节还要继续学习容器数据卷的一些内容

相关推荐

在 Ubuntu 上安装 Zabbix(以 Zabbix 6.4 LTS 版本为例)

Zabbix是一个流行的开源监控解决方案,能够监控各种网络参数和服务器健康状态。一、环境准备系统要求Ubuntu20.04/22.04LTS至少2GBRAM(生产环境建议4GB+)至少1...

如何在 Ubuntu 24.04 服务器上安装 Apache Solr

ApacheSolr是一个免费、开源的搜索平台,广泛应用于实时索引。其强大的可扩展性和容错能力使其在高流量互联网场景下表现优异。Solr基于Java开发,提供了分布式索引、复制、负载均衡及自...

如何在 Ubuntu 24.04 LTS 或 22.04/20.04 上安装 Apache Maven

Maven是由Apache托管的开源工具,用于管理Java项目。它包含一个项目对象模型(POM):一个配置文件(XML),其中包含项目的基本信息,包括配置、项目依赖项等。Maven可以处理...

Cursor的终极对手——Trae Pro最新系统提示词

前段时间,字节的AI编程神器Trae国际版,终于甩出了Pro订阅计划!很多对它又爱又恨的小伙伴,直呼:终于等到你。爱它,是因为Trae长期免费+体验真香;恨它?还不是那该死的排队等待,...

AI系统提示词:V0(ai代码提示)

以下是对V0系统提示词(SystemPrompt)的分部分讲解与解读,帮助你理解其核心内容和设计意图。V0系统提示词##CoreIdentity-Youarev0,Vercel&...

8岁男童失踪第13天,搜救人员发现可疑水库,更恶心的事情发生了

Lookingatyourrequest,Ineedtorewritethearticleaboutthe8-year-oldmissingboywhilemaking...

docker常用指令及安装rabbitMQ(docker安装zabbix)

一、docker常用指令启动docker:systemctlstartdocker停止docker:systemctlstopdocker重启docker:systemctlrestart...

三步教你用Elasticsearch+PyMuPDF实现PDF大文件秒搜!

面对100页以上的大型PDF文件时,阅读和搜索往往效率低下。传统关系型数据库在处理此类数据时容易遇到性能瓶颈,而Elasticsearch凭借其强大的全文检索和分布式架构,成为理想解决方案。通过...

ElasticSearch中文分词插件(IK)安装

坚持原创,共同进步!请关注我,后续分享更精彩!!!前言ElasticSearch默认的分词插件对中文支持很不友好。一段话按规则会以每个中文字符来拆解,再分别建立倒排索引。如"中华人民共和国国歌...

SpringBoot使用ElasticSearch做文档对象的持久化存储?

ElasticSearch是一个基于Lucene的开源搜索引擎,广泛应用于日志分析、全文搜索、复杂查询等领域,在有些场景中使用ElasticSearch进行文档对象的持久化存储是一个很不错的选择...

Elasticsearch数据迁移方案(elasticsearch copyto)

前言最近小编要去给客户部署一套系统涉及到了Mysql和ES数据的迁移,下面就给大家分享一下ES数据迁移的几套方案,根据具体的使用场景来选择不同的迁移方案能使你事倍功半,话多说下面就一一介绍。Elast...

Rancher部署单体ElasticSearch(rancher2.5部署)

Rancher是k8s图形管理界面,之前曾有写文章介绍如何安装。ElasticSearch是热门搜索引擎,很多地方都有用到,常规安装部署略显繁琐,本文介绍在k8s下用rancher简易部署ES。1.在...

Elasticsearch在Java项目的搜索实践:从零开始构建高效搜索系统

Elasticsearch在Java项目中的搜索实践:从零开始构建高效搜索系统在现代的Java项目中,数据量激增,传统的数据库查询方式已经无法满足快速检索的需求。这时,Elasticsearch(E...

小白入门-Kibana安装(kibana安装配置)

一Kibana基础1.1介绍Kibana是一款免费且开放的前端应用程序,其基础是ElasticStack,可以为Elasticsearch中索引的数据提供搜索和数据可视化功能。Kiban...

Docker上使用Elasticsearch,Logstash,Kibana

在对一个项目做性能测试时我需要处理我们web服务器的访问日志来分析当前用户的访问情况。因此,我想这是试用ELK的一个好机会。ELK栈首先要注意的是使用它是非常简单的。从决定使用ELK到在本机上搭一个...

取消回复欢迎 发表评论: