Docker学习重点(6)~容器数据卷

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: Docker学习重点(6)~容器数据卷

一、容器数据卷

1、什么是容器卷

docker是要将应用和环境打包成一个镜像

这样,数据就不应该在容器中,否则容器删除,数据就会丢失,这就是删库跑路

故容器之间要有一个数据共享技术


在Docker容器中产生的数据,同步到本地,这就是卷技术


2、容器卷的本质:

本质上是一个目录挂载,将容器内的目录挂载到虚拟机上


3、容器卷挂载目录的目的:

容器的持久化和同步操作, 实现容器间可以数据共享


二、使用数据卷

1、方式一:直接使用命令来挂载 —v volume卷技术

  • 命令:docker run -it -v 主机目录:容器内目录
[root@kuangshen home]# docker run-it -v/home/ceshi:/home centos/bin/bash

  • 启动起来时候我们可以通过 docker inspect 容器id
  • 新开一个窗口
docker inspect 容器id

  • 找到挂载信息Mounts

  • 测试:数据同步

  • 再来测试(容器停止后,修改主机文件,再启动容器的时候,数据同样改变):
    1、停止容器
    2、宿主机上修改文件
    3、启动容器
    4、容器内的数据依旧是同步的!

双向同步


4、使用容器数据卷的好处:

我们以后修改,只需在本地修改即可,容器内会自动同步!


三、实战安装mysql

  • MySQL的数据持久化命令
# 拉取
docker pull mysql:5.7
# 挂载
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=admin --name mysql01 mysql:5.7
-d 后台运行
-p 端口映射
-v 卷挂载
-e 环境配置 安装启动mysql需要配置密码
--name 容器名字
  • 连接测试:打开mysql的客户端工具:

● 如果,我们将容器mysql01删除,发现:

  • 我们挂载到本地的数据卷依然没有丢失,这就实现了容器数据持久化的功能!


四、具名和匿名挂载

1、匿名挂载和具名挂载的区别:

  • 匿名挂载:不写宿主机目录
  • 具名挂载:会给宿主机起一个名字
#匿名挂载  -v 容器内路径!
docker run -d -P --name nginx01 -v /ect/nginx nginx  
#查看所有的 volume 的情况
[root@kuangshen home]# docker volume 1s
local 9f38292179faa178afcce54d80be99d4ddd68c91d2a68870bcece72d2b7ed061 
#这里发现,这种就是匿名挂载,我们在—v 只写了容器内的路径,没有写容器外的路径!
#具名挂载
[root@kuangshen home]#docker run-d-P--name nginx02 -v juming-nginx:/etc/nginx nginx 
95b809564484c8ac87d65c69643e7e67447f1c77ff9a91b93edec7003692e3a9
[root@kuangshen home]# docker volume 1s 
DRIVER VOLUME NAME 
local  juming-nginx # 通过—v 卷名:容器内路径
#查看一下这个卷
  • 所有的docker容器内的卷,没有指定的目录的情况下都是在/var/lib/docker/volumes/xxx/_data

如何确定是具名挂载还是匿名挂载,还是指定路径挂载!

  • -v 容器內路径 # 匿名挂载
  • -v 卷名:容器内路径 # 具名挂载
  • -v 宿主机路径:容器内路径 # 指定路径挂载!

2、拓展:ro、rw

# 通过 —v 容器内路径:ro(readonly) rw(readwrite) 改变读写权限 
#一旦这个了设置了容器权限,容器对我们挂载出来的内容就有限定了!
docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx:ro nginx 
docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx:rw nginx 
#ro 只要看到ro就说明这个路径只能通过宿主机来操作,容器内部是无法操作!


五、初始Dockerfile

1、(目录挂载、数据同步)方式二:DockerFile使用来构建docker镜像的文件!命令脚本!

  • 通过这个脚本可以生成镜像,镜像时一层一层的,脚本是一个一个的命令,每个命令都是一层!

镜像是一层一层的,脚本是一行一行的

  • Dockerfile 内容:
# 指令都是大写的、
# 创建一个dockerfile文件,命名为Dockerfile
#文件内容:·
FROM centos   # 一层
VOLUME ["volume01","volume02"]  # 一层 再创建镜像的时候就挂载出来
CMD echo "---end---"    # 一层
CMD /bin/bash    # 一层
  • 构建Dockerfile:
docker build -f /home/docker-test-volume/dockerfile1 -t shan/centos

■ 测试:在容器内部创建一个文件

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

  • 查看Mounts,Source对应容器外目录,匿名挂载卷

  • 测试一下,在container volume01下生成文件:

  • 在主机挂载路径下,也同样生成(数据同步)

● 这种方式我们未来使用的十分多,因为我们通常会构建自己的镜像!假设构建镜像时候没有挂载卷,

手动镜像挂载 —v卷名:容器内路径!


六、数据卷容器---多个容器数据共享

  • 多个mysql 同步数据

1、多个容器数据共享

数据卷的继承关系 --volumes-from

  • 创建两个容器:

  • 数据卷的继承关系:

--volumes-from

  • 启动docker01,用之前建的shan/centos 1.0 镜像
docker run -it --name docker01 shan/centos:1.0 # 1.0必须写
docker run -it --name docker02 --volumes-from docker01 shan/centos:1.0


2、数据卷共享数据是拷贝


3、结论:

容器之间配置信息的传递,数据卷容器的生命周期一直持续到没有容器使用为止。

但是如果持久化到了本地,即使所有容器删除了,本地数据是不会删除的!


☺ 参考来源:

狂神的B站视频《【狂神说Java】Docker最新超详细版教程通俗易懂》 https://www.bilibili.com/video/BV1og4y1q7M4


如果本文对你有帮助的话记得给一乐点个赞哦,感谢!

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
23天前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
180 77
|
5天前
|
搜索推荐 安全 数据安全/隐私保护
7 个最能提高生产力的 Docker 容器
7 个最能提高生产力的 Docker 容器
74 35
|
1月前
|
监控 Docker 容器
在Docker容器中运行打包好的应用程序
在Docker容器中运行打包好的应用程序
|
4天前
|
Ubuntu Linux 开发工具
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
Docker 是一个开源的容器化平台,允许开发者将应用程序及其依赖项打包成标准化单元(容器),确保在任何支持 Docker 的操作系统上一致运行。容器共享主机内核,提供轻量级、高效的执行环境。本文介绍如何在 Ubuntu 上安装 Docker,并通过简单步骤验证安装成功。后续文章将探讨使用 Docker 部署开源项目。优雅草央千澈 源、安装 Docker 包、验证安装 - 适用场景:开发、测试、生产环境 通过以上步骤,您可以在 Ubuntu 系统上成功安装并运行 Docker,为后续的应用部署打下基础。
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
|
10天前
|
Unix Linux Docker
CentOS停更沉寂,RHEL巨变限制源代:Docker容器化技术的兴起助力操作系统新格局
操作系统是计算机系统的核心软件,管理和控制硬件与软件资源,为用户和应用程序提供高效、安全的运行环境。Linux作为开源、跨平台的操作系统,具有高度可定制性、稳定性和安全性,广泛应用于服务器、云计算、物联网等领域。其发展得益于庞大的社区支持,多种发行版如Ubuntu、Debian、Fedora等满足不同需求。
37 4
|
25天前
|
数据建模 应用服务中间件 nginx
docker替换宿主与容器的映射端口和文件路径
通过正确配置 Docker 的端口和文件路径映射,可以有效地管理容器化应用程序,确保其高效运行和数据持久性。在生产环境中,动态替换映射配置有助于灵活应对各种需求变化。以上方法和步骤提供了一种可靠且易于操作的方案,帮助您轻松管理 Docker 容器的端口和路径映射。
80 3
|
1月前
|
存储 缓存 监控
Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
本文介绍了Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
95 7
|
1月前
|
负载均衡 网络协议 算法
Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式
本文探讨了Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式,以及软件负载均衡器、云服务负载均衡、容器编排工具等实现手段,强调两者结合的重要性及面临挑战的应对措施。
74 3
|
1月前
|
存储 安全 数据安全/隐私保护
Docker 容器化应用管理更加高效,但数据安全和业务连续性成为关键。
在数字化时代,Docker 容器化应用管理更加高效,但数据安全和业务连续性成为关键。本文探讨了 Docker 应用的备份与恢复策略,涵盖备份的重要性、内容、方法及常见工具,制定备份策略,恢复流程及注意事项,并通过案例分析和未来趋势展望,强调备份与恢复在保障应用安全中的重要性。
37 2
|
1月前
|
存储 安全 数据中心
Docker 容器凭借轻量级和高效的特性,成为应用部署的重要工具
Docker 容器凭借轻量级和高效的特性,成为应用部署的重要工具。本文探讨了 Docker 如何通过 Namespace 和 Cgroups 实现 CPU、内存、网络和存储资源的隔离,提高系统安全性和资源利用率,以及面临的挑战和应对策略。
47 1