docker数据持久化及配置Volume和mount实践

 更新时间:2026年03月04日 10:00:45   作者:Y。S。H。  
文章主要讨论了Docker容器的存储问题,包括只读层与读写层的复制、容器删除导致的数据丢失、以及Docker提供的三种解决方案:bindmount、volume和tmpfs,文章还详细介绍了volume的优点,并提供了一些命令解析和挂载的使用方法

容器自身存储的问题

Docker镜像是由多个文件系统(只读层)叠加而成,容器启动的时候是在原镜像层上面加了一层可读写层,容器层,如果运行中的容器修改了现有的一个已经存在的文件,那该文件将会从读写层下面的只读层复制到读写层,该文件的只读版本仍然存在,只是已经被读写层中该文件的副本所隐藏。当删除Docker容器,并通过该镜像重新启动时,之前的更改将会丢失。

1、由于docker自身存储的方式,导致读写效率会降低,因为需要将只读层先复制到读写层这样的过程

2、当删除Docker容器,容器层数据也会删除

3、数据迁移共享和管理不便

提醒:网上好多版本说容器重启就会丢失数据,不知道为什么有这样的结论,容器层存在的话应该不存在数据丢失问题

docker提供三种解决方案

  • bind mount:将宿主机中的文件、目录mount挂载到容器上,依赖宿主机。
  • volume:volume由docker管理,比如创建、删除什么的。默认volume的存储空间/var/lib/docker/volumes/创建的卷名称,volume是官方推荐的持久化方案。
  • tmpfs mount:如果您的容器生成非持久状态数据,可以使用 tmpfs挂载以避免将数据永久存储在任何地方,并通过避免写入容器的可写层来提高容器的性能

bind mount和volume基本都差不多,只是针对特殊场景和需求而选择

看下官网说的volume的优点

1、volume可命令或Docker API管理 (mount没有任何命令管理)

2、volume在Linux和Windows容器上均可工作(mount依赖宿主机格式)

3、volume更易于备份或迁移

4、可以在多个容器之间更安全地共享volume

5、持久化数据到远程主机或者云存储而非本地 (具体的存储可以不在宿主机上,mount依赖宿主机)

6、volume的内容可以由容器预先填充 (volume 会保留原目录数据,mount会屏蔽原目录数据)

  • 如果将空volume挂载到container上的某个目录,此目录下原来的文件与子目录会复制到空volume中。
  • 如果mount一个非空目录或者文件,或者非空volume,则container目录中的原始内容将被遮蔽,当解决挂载时则自动恢复。

也参考这一篇:点击进入

官网命令解析:

运行后容器,官方是没有提供任何可以执行的操作添加存储方式

1、镜像run的使用 加上参数配置

2、 commit提交副本镜像,重新启动新镜像加上参数配置(针对容器已经有数据的情况下)

–mount

由多个名值对组成,逗号分隔,每个键值由 = 元组组成。–mount 语法比 -v 或 --volume更冗长,但键的顺序并不重要,并且标志的值更易于理解

 docker run  -itd --mount type=bind,source=/root,target=/tmp ubuntu /bin/bash
  • 要挂载的类型 type,可以是 bind、volume 或 tmpfs。
  • 要挂载的源 source,对于有名字的卷,这里是卷的名字。对于匿名卷忽略这个字段。可以指定为 src 或 source。
  • 要挂载的目的地 destination,将文件或目录挂载在容器中的路径作为其值。 可能被指定为 destination、dst 或target。
  • 只读选项 readonly,这个选项会使得挂载到容器中的绑定挂载只读。
  • volume-opt可以多次指定的选项采用键值对,该键值对由选项名称及其值组成。
  • 最后的/bin/bash,表示一旦容器启动,需要运行的命令,此时使用“/bin/bash”,表示什么也不做,只需进入命令行即可

-v或–volume

由三个字段组成,以冒号(:)分隔。这些字段必须以正确的顺序排列,并且每个字段的含义不是立即显而易见的。

docker volume create centos7
创建一个卷名称centos7

docker volume ls
查看卷

docker run  -itd -v cetnos7:/root  ubuntu /bin/bash
  • 第一个字段是卷的名称,在给定的主机上是唯一的。对于匿名卷,将省略第一个字段。
  • 第二个字段是文件或目录在容器中的安装路径。
  • 第三个字段是可选的,看官方手册
 docker volume create my-vol #创建数据卷
 docker volume ls #查看有哪些卷
 docker volume inspect my-vol #查看卷详情 
 docker rm -f web #强制删除运行中的容器
 docker volume rm my-vol #删除卷
 docker volume prune #清理无用的卷
 docker ps -s #可以查看容器的大小是没有增加的

我们怎么看容器是否挂载存储呢?

docker inspect eb5e31fef691
查看容器详细信息

容器本身存储

mount挂载

volume挂载

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 怎样获取docker动态分配的port

    怎样获取docker动态分配的port

    这篇文章给大家主要介绍了如何获取docker动态分配的port,文中通过分析、解决以及后续可能遇到的问题都给大家详细介绍了,有需要的朋友们可以参考借鉴,下面来一起看看吧。
    2016-10-10
  • Docker简单安装与应用入门教程

    Docker简单安装与应用入门教程

    这篇文章主要介绍了Docker简单安装与应用,结合实例形式分析了Docker常见的安装、应用构建、终端访问等操作相关实现技巧与注意事项,需要的朋友可以参考下
    2018-06-06
  • 将Docker容器打包并在其他服务器上运行的全过程

    将Docker容器打包并在其他服务器上运行的全过程

    Docker容器使得应用程序的部署和管理变得更加简单和高效,有时,我们可能需要将一个运行中的Docker容器打包,并在其他服务器上运行,本文将详细介绍如何实现这一过程,需要的朋友可以参考下
    2024-05-05
  • docker镜像仓库常用命令分享

    docker镜像仓库常用命令分享

    这篇文章主要介绍了docker镜像仓库常用命令,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-06-06
  • dockerfile构建haproxy的详细过程(构建HAProxy的镜像)

    dockerfile构建haproxy的详细过程(构建HAProxy的镜像)

    Dockerfile是一个用于构建Docker镜像的文本文件,包含了构建镜像所需的所有指令和说明,通过定义一系列命令和参数,本文详细介绍了如何使用Dockerfile一步步构建HAProxy的镜像,并指导如何创建和运行容器,实现负载均衡服务,感兴趣的朋友一起看看吧
    2025-03-03
  • Docker如何根据名称查询容器ID镜像ID并停止删除

    Docker如何根据名称查询容器ID镜像ID并停止删除

    这篇文章主要介绍了Docker如何根据名称查询容器ID镜像ID并停止删除问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • docker之docker-machine用法详解

    docker之docker-machine用法详解

    这篇文章主要介绍了docker之docker-machine用法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • Portainer部署和添加其他docker服务器的方法

    Portainer部署和添加其他docker服务器的方法

    文章介绍了如何部署Portainer并添加其他Docker服务器,本文给大家介绍的非常详细,感兴趣的朋友一起看看吧
    2025-03-03
  • 手把手带大家通过Docker部署前后端分离项目(亲测可用)

    手把手带大家通过Docker部署前后端分离项目(亲测可用)

    近年来前后端分离已经成为中大型软件项目开发的最佳实践,下面这篇文章主要给大家介绍了关于通过Docker部署前后端分离项目的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-06-06
  • 使用docker compose快速配置一组容器服务详解

    使用docker compose快速配置一组容器服务详解

    这篇文章主要为大家介绍了使用docker- compose快速配置一组容器服务详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-11-11

最新评论