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

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 通过前面的学习,我们知道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

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
17天前
|
Kubernetes Cloud Native 微服务
探索云原生技术:容器化与微服务架构的融合之旅
本文将带领读者深入了解云原生技术的核心概念,特别是容器化和微服务架构如何相辅相成,共同构建现代软件系统。我们将通过实际代码示例,探讨如何在云平台上部署和管理微服务,以及如何使用容器编排工具来自动化这一过程。文章旨在为开发者和技术决策者提供实用的指导,帮助他们在云原生时代中更好地设计、部署和维护应用。
|
13天前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
143 77
|
21天前
|
监控 Docker 容器
在Docker容器中运行打包好的应用程序
在Docker容器中运行打包好的应用程序
|
5天前
|
关系型数据库 应用服务中间件 PHP
实战~如何组织一个多容器项目docker-compose
本文介绍了如何使用Docker搭建Nginx、PHP和MySQL的环境。首先启动Nginx容器并查看IP地址,接着启动Alpine容器并安装curl测试连通性。通过`--link`方式或`docker-compose`配置文件实现服务间的通信。最后展示了Nginx配置文件和PHP代码示例,验证了各服务的正常运行。
21 3
实战~如何组织一个多容器项目docker-compose
|
15天前
|
数据建模 应用服务中间件 nginx
docker替换宿主与容器的映射端口和文件路径
通过正确配置 Docker 的端口和文件路径映射,可以有效地管理容器化应用程序,确保其高效运行和数据持久性。在生产环境中,动态替换映射配置有助于灵活应对各种需求变化。以上方法和步骤提供了一种可靠且易于操作的方案,帮助您轻松管理 Docker 容器的端口和路径映射。
55 3
|
18天前
|
Kubernetes Cloud Native Docker
云原生之旅:从容器化到微服务
本文将带领读者踏上云原生的旅程,深入探讨容器化和微服务架构的概念、优势以及它们如何共同推动现代软件的发展。我们将通过实际代码示例,展示如何在Kubernetes集群上部署一个简单的微服务应用,并解释相关的配置和操作。无论你是云原生新手还是希望深化理解,这篇文章都将为你提供有价值的见解和实操指南。
|
21天前
|
存储 缓存 监控
Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
本文介绍了Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
54 7
|
21天前
|
存储 Prometheus 监控
Docker容器内进行应用调试与故障排除的方法与技巧,包括使用日志、进入容器检查、利用监控工具及检查配置等,旨在帮助用户有效应对应用部署中的挑战,确保应用稳定运行
本文深入探讨了在Docker容器内进行应用调试与故障排除的方法与技巧,包括使用日志、进入容器检查、利用监控工具及检查配置等,旨在帮助用户有效应对应用部署中的挑战,确保应用稳定运行。
30 5
|
21天前
|
开发框架 安全 开发者
Docker 是一种容器化技术,支持开发者将应用及其依赖打包成容器,在不同平台运行而无需修改。
Docker 是一种容器化技术,支持开发者将应用及其依赖打包成容器,在不同平台运行而无需修改。本文探讨了 Docker 在多平台应用构建与部署中的作用,包括环境一致性、依赖管理、快速构建等优势,以及部署流程和注意事项,展示了 Docker 如何简化开发与部署过程,提高效率和可移植性。
49 4
|
21天前
|
负载均衡 网络协议 算法
Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式
本文探讨了Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式,以及软件负载均衡器、云服务负载均衡、容器编排工具等实现手段,强调两者结合的重要性及面临挑战的应对措施。
49 3