Docker挂载点

embedded/2025/1/17 1:14:59/

在Docker中,挂载点用于将宿主机上的目录映射到容器内的目录,这样可以实现数据的持久化存储和容器之间的数据共享。通过挂载点,容器可以访问宿主机上的文件系统,同时也能够持久化数据,即使容器本身被销毁,数据依然保留。

* 挂载点的作用
  1. 数据持久化:
    Docker容器是临时的,容器中的数据如果不通过挂载点进行存储,则容器被销毁后,数据也会丢失。通过挂载宿主机的目录到容器内的某个路径,可以保证数据持久化存储,容器重新启动或销毁后,数据不会丢失。

  2. 数据共享:
    在多个容器之间共享数据。通过挂载相同的宿主机目录到多个容器中,多个容器就可以访问和修改同一份数据,从而实现数据共享。

  3. 与宿主机的交互:
    容器内的数据和文件可以通过挂载点与宿主机的文件系统进行交互。例如,容器中的日志文件、数据库文件、配置文件等可以存储在宿主机上,方便容器外部查看和管理。

* 使用VOLUME指令定义挂载点

VOLUME指令用于在Dockerfile中指定容器的挂载点。它会在容器的文件系统中创建一个卷(volume),并将其挂载到容器的指定路径。

dockerfile">VOLUME ["/data"]

这条指令会在容器中创建一个挂载点/data,它会将宿主机上的一个目录(通常是临时的或匿名的卷)挂载到该路径。

使用VOLUME指令时,它并不会指定宿主机的路径,而是由Docker自动管理该卷。这种方式主要适用于容器之间共享数据,但不依赖于宿主机文件系统路径。

docker_run_25">* 使用docker run命令挂载宿主机目录

在启动容器时,我们可以使用-v参数来指定宿主机的目录和容器的目录之间的挂载关系。通过这种方式,宿主机上的文件可以映射到容器内,容器也可以修改宿主机上的数据。

挂载格式:

-v <宿主机目录>:<容器内目录>

例如,将宿主机的/path/on/host目录挂载到容器/path/in/container目录:

docker run -v /path/on/host:/path/in/container myimage

容器内对/path/in/container目录的操作会直接影响宿主机上的/path/on/host目录,反之亦然。

* 使用-v--mount参数指定挂载点

-v参数适用于大多数情况下的简单挂载,而--mount参数可以提供更复杂的挂载配置,并且具有更清晰的语法。

  1. 使用-v参数:

    docker run -v /path/on/host:/path/in/container myimage
    
  2. 使用--mount参数:

    --mount参数提供了更多选项,特别适合挂载名为卷的存储。

    例如,挂载宿主机的文件夹到容器内:

    docker run --mount type=bind,source=/path/on/host,target=/path/in/container myimage
    

    另外,如果你想使用Docker管理的卷,可以使用--mount来指定:

    docker run --mount type=volume,source=myvolume,target=/path/in/container myimage
    
* 挂载点的类型

在Docker中,挂载点有三种主要类型:

  1. 绑定挂载(Bind Mounts):

    • 绑定挂载将宿主机的文件或目录直接挂载到容器中。
    • 它适用于需要访问宿主机文件系统的场景,例如,容器读取或写入日志文件、配置文件、数据库文件等。
    • 绑定挂载的路径必须是宿主机上的绝对路径。

    示例:

    docker run -v /path/on/host:/path/in/container myimage
    
  2. 卷(Volumes):

    • 卷是由Docker管理的独立存储,可以挂载到容器中。
    • 卷通常用于持久化存储数据,并且可以在多个容器之间共享。
    • 它比绑定挂载更灵活,且通常用于数据库、日志文件等需要持久化存储的数据。
    • 卷的好处是它能够在容器销毁时保持数据,而不依赖于宿主机的文件路径。

    示例:

    docker run --mount type=volume,source=myvolume,target=/path/in/container myimage
    
  3. 匿名卷(Anonymous Volumes):

    • 匿名卷是没有名称的卷,Docker会在运行时自动创建并管理。
    • 它们通常用于存储容器数据,但并不需要手动命名或管理。

    示例:

    docker run -v /path/in/container myimage
    
* 卷与容器之间的交互

通过卷(Volumes),Docker实现了容器与宿主机之间的解耦,使得容器在生命周期中更具灵活性。例如,容器可以在销毁后继续访问存储在卷中的数据,同时卷也可以跨容器共享使用。

常见操作包括:

  • 创建卷:

    docker volume create myvolume
    
  • 查看卷:

    docker volume ls
    
  • 删除卷:

    docker volume rm myvolume
    
  • 查看卷的详细信息:

    docker volume inspect myvolume
    
* 挂载点的用途和最佳实践
  1. 数据持久化: 在开发过程中,容器的生命周期通常较短,数据也常常随容器的删除而丢失。通过挂载宿主机目录或卷,数据可以在容器生命周期结束后得以保存。

  2. 配置共享: 如果多个容器需要访问相同的配置文件或数据文件,使用挂载点可以让它们访问宿主机或其他容器的共享数据。

  3. 数据库存储:容器中运行数据库时,使用卷来存储数据库数据可以确保即使容器被销毁,数据依然能够保留。

  4. 避免数据丢失: 避免在容器内直接存储需要长期保存的数据,因为容器销毁时数据会丢失。将数据存储在挂载的卷中,能保证数据安全。

总结
  • 挂载点通过VOLUME指令或-v--mount参数,将宿主机的目录或文件系统挂载到容器内,便于数据持久化和共享。
  • 使用挂载点,容器可以访问宿主机的文件,同时也能确保数据不会随着容器的销毁而丢失。
  • 绑定挂载、卷和匿名卷是Docker常用的挂载类型,每种类型有不同的使用场景和优势。

http://www.ppmy.cn/embedded/154520.html

相关文章

Android Room 报错:too many SQL variables (code 1 SQLITE_ERROR) 原因及解决方法

报错信息&#xff1a; android.database.sqlite.SQLiteException: too many SQL variables (code 1 SQLITE_ERROR): while compiling: SELECT * FROM points WHERE id IN (?,?,?,...,?,?,?)SQLiteException: too many SQL variables 通常是由于一次查询或插入的 SQL 语句…

我的年度总结

这一年的人生起伏&#xff1a;从曙光到低谷再到新的曙光 其实本来没打算做年度总结的&#xff0c;无聊打开了帅帅的视频&#xff0c;结合自己最近经历的&#xff0c;打算简单聊下。因为原本打算做的内容会是一篇比较丧、低能量者的呻吟。 实习生与创业公司的零到一 第一段工…

Unity ShaderGraph中Lit转换成URP的LitShader

ShaderGraph中的LitShader如下&#xff1a; 在顶点和片元着色器暴露出了上图中的几个参数&#xff0c;要转换成URPLitShaderLab,首先要找到这几个参数&#xff0c;打开LitShader&#xff0c;找到第一个Pass&#xff0c;可以看到下图中的顶点和片元的定义函数&#xff0c;还有引…

云计算技术深度解析与代码实践

云计算技术深度解析与代码实践 引言 云计算作为近年来兴起的革命性IT服务模式&#xff0c;正在全球范围内迅速普及。它通过网络将软硬件资源整合成一个高效的分布式系统&#xff0c;实现了数据的可靠存储和高效处理。本文将深入探讨云计算的技术特点、应用场景&#xff0c;并…

用 Python 从零开始创建神经网络(二十):模型评估

模型评估 引言 引言 在第11章《测试或样本外数据》中&#xff0c;我们讨论了验证数据和测试数据之间的区别。对于目前的模型&#xff0c;我们在训练过程中进行了验证&#xff0c;但目前没有一个好的方法来对测试数据运行测试或进行预测。首先&#xff0c;我们将在Model类中添加…

Nacos 配置与服务注册问题排查指南

Nacos 配置与服务注册问题排查指南 1. Nacos 配置文件优先级 在 Spring Boot 应用中&#xff0c;配置文件的优先级从高到低依次为&#xff1a; bootstrap.propertiesbootstrap.ymlapplication.propertiesapplication.yml 2. Nacos 配置中心配置示例 以下是一个典型的 Naco…

List 接口的实现类

在 Java 中&#xff0c;List 是一个非常常用的接口&#xff0c;提供了有序、可重复的元素集合。List 接口有多个实现类&#xff0c;每个实现类都有其特定的特性和适用场景。以下是 Java 中主要实现了 List 接口的类及其详细介绍。 1. 常见的 List 实现类 1.1 ArrayList 简介&…

Flink CDC 在阿里云实时计算Flink版的云上实践

摘要&#xff1a;本文整理自阿里云高级开发工程师&#xff0c;Apache Flink Committer 阮航老师在 Flink Forward Asia 2024 生产实践&#xff08;三&#xff09;专场中的分享&#xff0c;主要分为以下四个方面&#xff1a; Flink CDC & 实时计算 Flink CDC YAML 核心功能…