Docker容器数据卷入门教程(超详细)

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: docker的理念将运行的环境打包形成容器运行,运行可以伴随容器,但是我们对数据的要求是希望持久化,容器之间可以共享数据,Docker容器产生的数据,如果不通过docker commit生成新的镜像,使得数据作为容器的一部分保存下来,那么当容器被删除之后,数据也就没了。为了能够保存数据,在docker容器中使用卷。

概念

什么是数据卷?

docker的理念将运行的环境打包形成容器运行,运行可以伴随容器,但是我们对数据的要求是希望持久化,容器之间可以共享数据,Docker容器产生的数据,如果不通过docker commit生成新的镜像,使得数据作为容器的一部分保存下来,那么当容器被删除之后,数据也就没了。为了能够保存数据,在docker容器中使用卷。
卷就是目录或者文件,存在于一个或者多个容器中,但是不属于联合文件系统,因此能够绕过Union File System提供一些用于持久化数据或共享数据的特点。

功能及特点

卷的设计目的就是数据的持久化,完全独立于容器的生存周期,因此Docker不会在容器删除时删除其挂载的数据卷。
数据卷特点:

  1. 数据卷可在容器之间共享或重用数据
  2. 数据卷中的更改可以直接生效
  3. 数据卷中的更改不会包含在镜像的更新中
  4. 数据卷的生命周期一直持续到没有容器使用它为止

使用数据卷

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

方法一 直接使用命令挂载

命令:docker run -it -v 主机目录:容器内目录

启动容器

ubuntu@VM-4-3-ubuntu:~$ sudo docker run -it --name="centos01" -v /home/docker-centos:/home centos

启动后通过命令 docker inspect 容器id查看具体信息
在这里插入图片描述
测试文件的同步
在这里插入图片描述
进一步测试,进行以下操作

  1. 停止正运行的docker容器
  2. 在宿主机上修改文件test.java,写入hello docker from docker-centos
  3. 启动刚刚停止的容器
  4. 查看容器内的数据是否会同步

在这里插入图片描述
总结:容器的持久化和同步操作,容器间也可共享

方法二 匿名挂载

命令:docker run -it -v 容器内路径

以nginx为列,启动容器docker run -d -P --name nginx01 -v /etc/nginx nginx

容器启动后,使用命令doocker inspect 容器id查看一下元数据,可以看到卷的位置如下图
在这里插入图片描述

方法三 具名挂载

命令:docker run -it -v 卷名:容器内路径

启动容器 docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx nginx
使用命令doocker inspect 容器id查看一下元数据,可以看到卷的位置如下图
在这里插入图片描述
总结
如何确定试具名挂载还是匿名挂载,还是指定路径挂载

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

扩展(读写权限)

通过 -v 容器内路径:ro rw改变读写权限

ro  readonly   #只读
rw  readwrite  #可读可写

#一旦这个设置了容器权限,容器对挂载出来的内容就限定了
$ sudo docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx:ro nginx
$ sudo docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx:rw nginx

只要设置了ro说明这个路径只有通过宿主机来操作,容器内无法操作


数据卷容器

可实现多个容器的数据同步,比如多个mysql数据库同步数据

准备

  1. 启动一个centos容器,命名为bbx-centos01,做为父容器
  2. 创建两个新文件夹volume01volume02

这里的bbx-centos是在原有centos镜像制作的

在这里插入图片描述
启动子容器bbx-centos02继承 --volumes-from父容器bbx-centos01
在这里插入图片描述

测试
1.在centos01中volume01创建一个docker的文件,看centos02是否同步
2.在centos02中volume01创建一个docker2的文件,看centos01是否同步

在这里插入图片描述

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

目录
相关文章
|
11天前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
141 77
|
19天前
|
监控 Docker 容器
在Docker容器中运行打包好的应用程序
在Docker容器中运行打包好的应用程序
|
3天前
|
关系型数据库 应用服务中间件 PHP
实战~如何组织一个多容器项目docker-compose
本文介绍了如何使用Docker搭建Nginx、PHP和MySQL的环境。首先启动Nginx容器并查看IP地址,接着启动Alpine容器并安装curl测试连通性。通过`--link`方式或`docker-compose`配置文件实现服务间的通信。最后展示了Nginx配置文件和PHP代码示例,验证了各服务的正常运行。
18 3
实战~如何组织一个多容器项目docker-compose
|
13天前
|
数据建模 应用服务中间件 nginx
docker替换宿主与容器的映射端口和文件路径
通过正确配置 Docker 的端口和文件路径映射,可以有效地管理容器化应用程序,确保其高效运行和数据持久性。在生产环境中,动态替换映射配置有助于灵活应对各种需求变化。以上方法和步骤提供了一种可靠且易于操作的方案,帮助您轻松管理 Docker 容器的端口和路径映射。
54 3
|
19天前
|
负载均衡 网络协议 算法
Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式
本文探讨了Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式,以及软件负载均衡器、云服务负载均衡、容器编排工具等实现手段,强调两者结合的重要性及面临挑战的应对措施。
47 3
|
19天前
|
存储 安全 数据安全/隐私保护
Docker 容器化应用管理更加高效,但数据安全和业务连续性成为关键。
在数字化时代,Docker 容器化应用管理更加高效,但数据安全和业务连续性成为关键。本文探讨了 Docker 应用的备份与恢复策略,涵盖备份的重要性、内容、方法及常见工具,制定备份策略,恢复流程及注意事项,并通过案例分析和未来趋势展望,强调备份与恢复在保障应用安全中的重要性。
25 2
|
19天前
|
存储 缓存 监控
Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
本文介绍了Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
54 7
|
19天前
|
存储 Prometheus 监控
Docker容器内进行应用调试与故障排除的方法与技巧,包括使用日志、进入容器检查、利用监控工具及检查配置等,旨在帮助用户有效应对应用部署中的挑战,确保应用稳定运行
本文深入探讨了在Docker容器内进行应用调试与故障排除的方法与技巧,包括使用日志、进入容器检查、利用监控工具及检查配置等,旨在帮助用户有效应对应用部署中的挑战,确保应用稳定运行。
29 5
|
19天前
|
开发框架 安全 开发者
Docker 是一种容器化技术,支持开发者将应用及其依赖打包成容器,在不同平台运行而无需修改。
Docker 是一种容器化技术,支持开发者将应用及其依赖打包成容器,在不同平台运行而无需修改。本文探讨了 Docker 在多平台应用构建与部署中的作用,包括环境一致性、依赖管理、快速构建等优势,以及部署流程和注意事项,展示了 Docker 如何简化开发与部署过程,提高效率和可移植性。
46 4
|
19天前
|
存储 安全 数据中心
Docker 容器凭借轻量级和高效的特性,成为应用部署的重要工具
Docker 容器凭借轻量级和高效的特性,成为应用部署的重要工具。本文探讨了 Docker 如何通过 Namespace 和 Cgroups 实现 CPU、内存、网络和存储资源的隔离,提高系统安全性和资源利用率,以及面临的挑战和应对策略。
35 1
下一篇
DataWorks