Docker数据卷使用手册

2024-08-26 00:36
文章标签 数据 docker 使用手册

本文主要是介绍Docker数据卷使用手册,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

目标

前言

概念

官方文档

匿名卷(Anonymous Volumes)

简介

案例

命名卷(Named Volumes)

简介

案例


目标

  1. 掌握Volume命令
  2. 通过演示案例,理解数据卷种类与各自的用途。

前言

        我们在很多网上教程上可以看到很多老师们往往将数据卷划分为三个种类:匿名卷、命名卷、绑定挂载。但是我去官方网站看了相关文档,文档中十分明确地将绑定挂载(Bind mounts)、数据卷(Volumes)、临时挂载(tmpfs mounts)规定为三个类别。这可能是很多老师从命令的角度去考虑问题,因为-v参数也可以创建绑定挂载。但是对于这些概念性的东西每个人理解方式不同,我们不用过于纠结,只要理解他们之间的区别并且熟练使用就行相较于绑定挂载,官方推荐优先考虑使用数据卷。

  1. 其中临时挂载的数据存储在内存中,无法持久化。所以官方将它单独拎出来做一个独立的类型。
  2. 绑定挂载与数据卷在适用场景上有很大的区别。绑定挂载适用场景偏向于开发和测试阶段,功能更倾向于实时处理,比如代码热部署。
  3. 数据卷的适用场景偏向生产阶段,功能更偏向于安全和持久化,比如数据的持久化、MQ中间件。


概念

数据卷(Volume)

官方定义

Volumes

Volumes are the preferred mechanism for persisting data generated by and used by Docker containers.

Volumes are often a better choice than persisting data in a container's writable layer, because a volume doesn't increase the size of the containers using it, and the volume's contents exist outside the lifecycle of a given container.

翻译

卷是持久化Docker容器生成和使用数据的首选机制。

卷通常比在容器的可写层中持久化数据更好,因为卷不会增加使用它的容器的大小,而且卷的内容存在于给定容器的生命周期之外。

我的理解

  1. 将容器内的某些目录和主机内的某些目录做映射处理,主机内的这些目录就叫数据卷。容器内的这些目录中的数据在数据卷中持久化,可以做到删除容器,数据卷中的数据仍然存在。
  2. 可以把数据卷和MySQL数据库类比:数据卷和MySQL数据库都用于持久化数据。数据卷主要用于跨容器、容器重启、容器重建;MySQL倾向于结构化数据、事务管理、数据一致性等。

官方文档

数据卷的概念及使用方法 | Volumesicon-default.png?t=N7T8https://docs.docker.com/engine/storage/volumes/

数据卷基本命令 | docker volumeicon-default.png?t=N7T8https://docs.docker.com/reference/cli/docker/volume/


匿名卷(Anonymous Volumes)

简介

  1. 顾名思义,创建匿名卷时只需要指定容器的目录,不需要关心匿名卷的存储路径。
  2. 适用于临时数据处理、短期开发任务、重复的测试任务。

案例

        创建Nginx容器并把Nginx首页所在目录制作成匿名卷。通过修改容器内的首页内容、修改匿名卷内的首页内容、删除容器观察匿名卷等操作实现对匿名卷的初步了解。

第一步:创建Nginx容器,并将Nginx首页所在的目录做成匿名卷。

#-v表示创建数据卷,-v后面只写了一个目录,则这个目录表示容器内的目录。
docker run -d -p 8848:80 --name nginx -v /usr/share/nginx/html nginx

第二步:查看容器详情。可以发现我们的目标目录(Destination表示容器内的目录)和主机目录(Source)已经产生了关联。由于我们创建的是匿名卷,没有定义卷名,所以Docker为我们自动生成了一串哈希值(Name的值)。

docker inspect 23805528c4af

第三步:去浏览器访问Nginx,页面返回了Nginx的默认首页。此时我们修改容器内Nginx的首页并重启容器,发现首页内容改变了。

localhost:8848

#进入容器
docker exec -it 23805528c4af /bin/bash
#进入Nginx首页目录
cd /usr/share/nginx/html
#修改容器内容。有的镜像非常精简没有vi命令,大家可以用echo创建首页覆盖原来的首页。
echo '<h1>Hello World!<h1>' >index.html
#退出容器。
exit
#关闭容器
docker stop 23805528c4af
#启动容器
docker start 23805528c4af

第四步:根据第二步我们已经看到了数据卷的位置,我们来看看数据卷中的首页内容有没有发生变化。

第五步:修改数据卷中的首页内容,重启容器后访问Nginx,发现页面变化了。

第六步:分别在在容器和主机上,做创建文件、删除文件操作。发现数据卷的内容和容器内对应的目录内容一致。(操作略)

第七步:删除容器,观察数据卷是否还存在。发现还存在。

docker rm nginx

第八步:如果想实现删除容器的同时也删除匿名卷,可以有以下两种方法。

方法一:创建容器的时候使用--rm,这个参数表示容器停止后会自动删除该容器,以及相关的所有资源。

#创建容器
docker run -d -p 8848:80 --name nginx --rm -v /usr/share/nginx/html nginx
#查看数据卷
docker inspect nginx
#停止容器
docker stop nginx
#查看是否还存在数据卷
docker volume ls

方法二:如果创建容器时没有使用--rm,在删除容器时加上-v参数,表示也删除匿名卷。

#创建容器
docker run -d -p 8848:80 --name nginx -v /usr/share/nginx/html nginx
#查看数据卷
docker inspect nginx
#停止容器
docker rm -v nginx
#查看是否还存在数据卷
docker volume ls


命名卷(Named Volumes)

简介

  1. 创建命名卷时需要定义卷名。从容器的详细来看,命名卷的Name是我们自定义的,匿名卷的Name是Docker自动生成的哈希值。
  2. 容器的删除不会导致数据卷被删除。虽然匿名卷也能实现,但在创建容器或删除容器时添加特定的参数仍然会使得匿名卷被删除(上面介绍匿名卷的第八步有所体现),而命名卷不会因此被删除。
  3. 适合做数据持久化,比如数据库的存储目录和日志文件;适合做数据迁移备份;适合多个容器间共享数据。

案例

        创建Nginx容器并把Nginx首页所在目录制作成命名卷。通过停止容器、删除容器操作观察命名卷是否仍然存在。

第一步:创建Nginx容器,并将Nginx首页所在的目录做成命名卷。

#卷名是nginx-volume
docker run -d -p 8848:80 --name nginx -rm -v nginx-volume:/usr/share/nginx/html  nginx

第二步:停止容器,发现命名卷还是存在。注意:这个容器在创建时用了--rm参数。在之前的案例中,创建匿名卷时使用了这个参数,在停止容器时,匿名卷被删除了,而命名卷保留着。

第三步:创建新容器时不用--rm参数,在删除容器时使用-v参数,看命名卷是否存在。结论是命名卷仍然存在。

这篇关于Docker数据卷使用手册的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1107047

相关文章

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

GSON框架下将百度天气JSON数据转JavaBean

《GSON框架下将百度天气JSON数据转JavaBean》这篇文章主要为大家详细介绍了如何在GSON框架下实现将百度天气JSON数据转JavaBean,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言一、百度天气jsON1、请求参数2、返回参数3、属性映射二、GSON属性映射实战1、类对象映

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

Java+AI驱动实现PDF文件数据提取与解析

《Java+AI驱动实现PDF文件数据提取与解析》本文将和大家分享一套基于AI的体检报告智能评估方案,详细介绍从PDF上传、内容提取到AI分析、数据存储的全流程自动化实现方法,感兴趣的可以了解下... 目录一、核心流程:从上传到评估的完整链路二、第一步:解析 PDF,提取体检报告内容1. 引入依赖2. 封装

MySQL中查询和展示LONGBLOB类型数据的技巧总结

《MySQL中查询和展示LONGBLOB类型数据的技巧总结》在MySQL中LONGBLOB是一种二进制大对象(BLOB)数据类型,用于存储大量的二进制数据,:本文主要介绍MySQL中查询和展示LO... 目录前言1. 查询 LONGBLOB 数据的大小2. 查询并展示 LONGBLOB 数据2.1 转换为十

使用SpringBoot+InfluxDB实现高效数据存储与查询

《使用SpringBoot+InfluxDB实现高效数据存储与查询》InfluxDB是一个开源的时间序列数据库,特别适合处理带有时间戳的监控数据、指标数据等,下面详细介绍如何在SpringBoot项目... 目录1、项目介绍2、 InfluxDB 介绍3、Spring Boot 配置 InfluxDB4、I

Java整合Protocol Buffers实现高效数据序列化实践

《Java整合ProtocolBuffers实现高效数据序列化实践》ProtocolBuffers是Google开发的一种语言中立、平台中立、可扩展的结构化数据序列化机制,类似于XML但更小、更快... 目录一、Protocol Buffers简介1.1 什么是Protocol Buffers1.2 Pro

Python实现数据可视化图表生成(适合新手入门)

《Python实现数据可视化图表生成(适合新手入门)》在数据科学和数据分析的新时代,高效、直观的数据可视化工具显得尤为重要,下面:本文主要介绍Python实现数据可视化图表生成的相关资料,文中通过... 目录前言为什么需要数据可视化准备工作基本图表绘制折线图柱状图散点图使用Seaborn创建高级图表箱线图热

MySQL数据脱敏的实现方法

《MySQL数据脱敏的实现方法》本文主要介绍了MySQL数据脱敏的实现方法,包括字符替换、加密等方法,通过工具类和数据库服务整合,确保敏感信息在查询结果中被掩码处理,感兴趣的可以了解一下... 目录一. 数据脱敏的方法二. 字符替换脱敏1. 创建数据脱敏工具类三. 整合到数据库操作1. 创建服务类进行数据库