【云原生 | 从零开始学Docker】五、容器数据卷实战

简介: 通过前面的学习,我们知道docker是把应用和环境打包成镜像,那如果数据都在容器里,容器被删除数据就会丢失,我们需要让数据持久化。

一.什么是容器数据卷


通过前面的学习,我们知道docker是把应用和环境打包成镜像,那如果数据都在容器里,容器被删除数据就会丢失,我们需要让数据持久化。


卷又是什么呢?


容器之间有数据共享,产生数据同步到本地,其实就是个目录挂载,把容器内的目录挂载到虚拟机上或者linux上面,这就是卷。把容器里想要同步的镜像里的一个路径映射到本地,也就是容器的持久化和同步操作,容器之间可以数据共享。


二.操作


2.1 挂载数据卷


命令:docker run -it -v /宿主机绝对路径目录:/容器内目录:[权限] 镜像名


权限:可以通过容器内路径:rw这种方法修改权限为可读可写。


ro是只读,一旦设定了容器权限,容器对挂载出来的内容就有限定了。


默认rw, 如果为ro,这个路径只能通过宿主机来操作,容器内部无法操作。


可以通过在容器内路径后加上ro、rw来改变读写权限。


我们新建一个测试目录,然后使用命令:docker run -it -v /home/ceshi:/home centos /bin/bash 把centos映射到ceshi目录


使用之后会启动你在命令里写的镜像,然后我们进行测试。


首先使用docker inspect 容器id来查看


444.png


可以在信息里发现这个,source目的地,desti是容器内地址,此时我们在centos或者主机内操作就会同步,我们来试试。


6.png


这里可以看到操作同步了,我们再试试主机内删除


60.png


然后进入centos内


61.png


我们可以看到操作确实同步了。


62.png


并且在停止容器之后,他依然会同步!只要容器在,没被删除就可以同步,并且可以挂载多个。


2.2 挂载方式


所有docker容器内的卷,没有指定目录的情况下都在/var/lib/docker/volumes/xxxxx/_data


指定路径挂载


-v /主机路径:容器内路径 上面就是


具名挂载


docker run -d -P --name nginx03 -v juming-nginx:/etc/nginx nginx


这就是具名挂载,卷名:卷内路径。


我们可以通过docker volume ls来查看挂载过的


63.png


可以看到我们的具名挂载是有名字的,我们也可以通过查看juming-nginx来看具体信息


64.png


可以看到路径也是和我们上面说的默认路径一样的!大部分情况就是使用具名挂载。(默认路径是在宿主机)


匿名挂载


docker run -d -P(随机映射端口)--name nginx02 -v /etc/nginx nginx


不写主机目录,会自动生成,上面ls查看的乱码都是没有指定名字的匿名卷,因为挂载的时候只写了容器内的路径,没有写容器外的路径,这就是匿名挂载。


那么如何判断是怎么挂载呢


只有容器内路径 匿名
卷名:容器内路径 具名
宿主机:容器内 指定路径


三.实战mysql持久化数据


3.1 下载mysql


docker pull mysql:5.7


3.2 运行容器(做数据挂载)


同步两个目录 链接3310和3306端口并且配置环境(密码)


docker run -d -p 3310:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql:5.7


65.png


3.3 测试


我们使用外部访问工具链接mysql(我用的navicat)


66.png


67.png


成功连接,然后我们在navicat里面新建一个表,看看宿主机会不会同步!


68.png


新建一个测试,然后去主机的home/mysql/data下面查看


69.png


我们可以发现,确实同步了!然后我们删除容器,查看主机里的数据是否还在


7.png


数据还在


70.png

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
2月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
499 5
|
2月前
|
监控 Linux 调度
【赵渝强老师】Docker容器的资源管理机制
本文介绍了Linux CGroup技术及其在Docker资源管理中的应用。通过实例演示了如何利用CGroup限制应用程序的CPU、内存和I/O带宽使用,实现系统资源的精细化控制,帮助理解Docker底层资源限制机制。
236 6
|
2月前
|
Java Linux 虚拟化
【Docker】(1)Docker的概述与架构,手把手带你安装Docker,云原生路上不可缺少的一门技术!
1. Docker简介 1.1 Docker是什么 为什么docker会出现? 假定您在开发一款平台项目,您的开发环境具有特定的配置。其他开发人员身处的环境配置也各有不同。 您正在开发的应用依赖于您当前的配置且还要依赖于某些配置文件。 您的企业还拥有标准化的测试和生产环境,且具有自身的配置和一系列支持文件。 **要求:**希望尽可能多在本地模拟这些环境而不产生重新创建服务器环境的开销 问题: 要如何确保应用能够在这些环境中运行和通过质量检测? 在部署过程中不出现令人头疼的版本、配置问题 无需重新编写代码和进行故障修复
383 3
|
存储 Cloud Native 数据处理
从嵌入式状态管理到云原生架构:Apache Flink 的演进与下一代增量计算范式
本文整理自阿里云资深技术专家、Apache Flink PMC 成员梅源在 Flink Forward Asia 新加坡 2025上的分享,深入解析 Flink 状态管理系统的发展历程,从核心设计到 Flink 2.0 存算分离架构,并展望未来基于流批一体的通用增量计算方向。
340 0
从嵌入式状态管理到云原生架构:Apache Flink 的演进与下一代增量计算范式
|
4月前
|
运维 监控 Cloud Native
从本土到全球,云原生架构护航灵犀互娱游戏出海
本文内容整理自「 2025 中企出海大会·游戏与互娱出海分论坛」,灵犀互娱基础架构负责人朱晓靖的演讲内容,从技术层面分享云原生架构护航灵犀互娱游戏出海经验。
473 16
|
4月前
|
运维 监控 Cloud Native
从本土到全球,云原生架构护航灵犀互娱游戏出海
内容整理自「 2025 中企出海大会·游戏与互娱出海分论坛」,灵犀互娱基础架构负责人朱晓靖的演讲内容,从技术层面分享云原生架构护航灵犀互娱游戏出海经验。
|
2月前
|
人工智能 Kubernetes Cloud Native
Higress(云原生AI网关) 架构学习指南
Higress 架构学习指南 🚀写在前面: 嘿,欢迎你来到 Higress 的学习之旅!
660 0
|
8月前
|
运维 Cloud Native 测试技术
极氪汽车云原生架构落地实践
随着极氪数字业务的飞速发展,背后的 IT 技术也在不断更新迭代。极氪极为重视客户对服务的体验,并将系统稳定性、业务功能的迭代效率、问题的快速定位和解决视为构建核心竞争力的基石。