一、引入Docker数据卷的必然性

为了实现容器与主机之间、容器与容器之间共享文件,容器中数据的持久化,将容器中的数据备份、迁移、恢复等,Docker加入了数据卷(volumes)机制。简单的讲,就是做了一个文件夹的实时共享,有点像局域网的文件共享。

二、Docker挂载容器数据卷

目前Docker提供了三种不同的方式将数据从宿主机挂载到容器中:bind mounts、tmpfs mounts、Volumes三种方式。其实严格来讲tmpfs mounts不会挂载到宿主机上的。下面有讲解。

2.1、方式一:bind mounts

意为着可以存储在宿主机系统的任意位置。

但是,bind mount在不同的宿主机系统时不可移植的,比如Windows和Linux的目录结构是不一样的,bind mount所指向的host目录也不能一样。这也是为什么bind mount不能出现在Dockerfile中的原因,因为这样Dockerfile就不可移植了。

2.3、方式三:volumes

Docker管理宿主机文件系统的一部分,默认位于 /var/lib/docker/volumes 目录中;最常用的方式

2.3、方式二:tmpfs mounts

其中tmpfs是一种基于内存的临时文件系统。tmpfs mounts挂载存储在宿主机系统的内存中,而不会写入宿主机的文件系统。
三种方式挂载图解

三、bind mounts的基本使用

2.1、示例讲解
这里指定了将宿主机上的 /opt/wwwroot目录挂载到/usr/share/nginx/html

$ mkdir -p  /opt/wwwroot
$ docker run -itd --name=nginx-v1 -v /opt/wwwroot:/usr/share/nginx/html nginx

-v指定具体路径,如果不指定,那就在默认路径下/var/lib/docker/volumes/目录下随机产生一个挂载目录

可以看到,bind mounts的方式会隐藏掉被挂载目录里面的初始内容,这里是/usr/share/nginx/html目录下的内容被隐藏掉了,因此我们看不到。

然后我们创建新文件,就可以在容器里看到新创建的文件了。
宿主机:

容器里

2.2、查看容器详情,就可以看到我们绑定的路径

$ docker inspect nginx-v1


2.3、清理

$ docker stop nginx-v1
$ docker rm  nginx-v1
# 查看挂在目录
$ ll /opt/wwwroot/


通过图上所示,挂载目录里面的文件仍然还在,不会随着容器的结束而消失,从而实现数据持久化。

四、volumes的基本使用

4.1、管理卷

# 创建一个自定义容器卷,在/var/lib/docker/volumes/目录下创建
$ docker volume create nginx-vol1
# 查看所有容器卷
$ docker volume ls
# 查看指定容器卷详情信息
$ docker volume inspect nginx-vol1


4.2、创建使用指定卷的容器
有了自定义容器卷,我们可以创建一个使用这个数据卷的容器,这里我们以nginx为例:

$ docker run -itd --name=nginx-v1 -p 8080:80 -v nginx-vol1:/usr/share/nginx/html nginx

其中,-v代表挂载数据卷,这里使用自定数据卷nginx-vol1,并且将数据卷挂载到 /usr/share/nginx/html。
与bind mounts的区别在于不用自己创建目录,只有创建卷就行,卷其实也是目录,还有一点volumes就是可以查看/usr/share/nginx/html自带文件。

4.3、如果不加-v,则不会在默认路径下挂载目录

$ docker run -itd --name=nginx-v2 -p 8081:80  nginx
$ ls -l /var/lib/docker/volumes/


4.3、如果加-v,但是不指定宿主机的挂载目录,则会自动创建一个随机的挂载目录,这种方式是bind mounts,也看不到默认文件

$ docker run -itd --name=nginx-v4 -p 8084:80 -v :/usr/share/nginx/html nginx


4.4、删除容器

$ docker stop nginx-v1
$ docker rm nginx-v1


数据也不会因为容器被删除而删除,达到数据持久化的效果。

五、扩展(-volume)

高于17.06的docker可以将–mount用于为单一容器创建数据卷,两者的差别如下:

5.1、-v或是-volume包括三个区域,以分号分割

  • 第一个区域用于定义卷的名称,如果不指定,表明使用匿名卷,实名卷的名称在一台主机上唯一
  • 第二个区域指定卷对应容器中的哪个文件
  • 第三个区域是可选的,是用逗号分割的选项列表

5.2、-mount使用键值对=,以逗号分割,对应的值如下

  • type:可以是bind、volume、tmpfs,创建数据卷使用volume
  • source:挂载点的名字,对于实名卷,为实名卷的名字,匿名卷不需要使用这个关键字
  • destination:指定卷对应容器中的哪个文件
  • readonly:指定数据卷只可读
  • volume-opt:可以出现多次,其值为一个键值对(有什么用我还不知道)

-mount参数的值用单引号包含起来,将关键字对应值中出现的volume-opt用双引号括起来,如下:

$ docker service create \--mount 'type=volume,src=<VOLUME-NAME>,dst=<CONTAINER-PATH>,volume-driver=local,volume-opt=type=nfs,volume-opt=device=<nfs-server>:<nfs-path>,"volume-opt=o=addr=<nfs-address>,vers=4,soft,timeo=180,bg,tcp,rw"'--name myservice \<IMAGE>

5.2、-v与-mount的区别

-mount可以支持创建集群服务的数据卷,而-v不行,其余基本没差;怎么创建集群的话,会面写docker swarm会讲到。

5.3、创建、查看、删除数据卷:

# 创建实名数据卷
$ docker volume create my-vol# 创建匿名卷
$ docker volume create# 查看数据卷列表
$ docker volume ls# 查看具体的数据卷
$ docker volume inspect my-vol# 删除数据卷
$ docker volume rm my-vol

5.4、示例,数据卷会自动创建
1)在创建容器时指定数据卷

# 创建容器
$ docker run -d \--name devtest \--mount source=myvol1,target=/usr/share/nginx/html \nginx:latest

2)使用只读数据卷

#ro表示只读(readonly),-v==--mount
$ docker run -d \--name=nginxtest \-v nginx-vol:/usr/share/nginx/html:ro \nginx:latest
#  等价于下面命令
$ docker run -d \--name=nginxtest2 \--mount source=nginx-vol2,destination=/usr/share/nginx/html,readonly \nginx:latest

5.5、删除数据卷

$ docker volume ls
$ docker volume rm nginx-vol1
$ docker volume ls
# 删除所有卷,慎用
$ docker volume prune

注意:docker规定,没有容器正在使用数据卷后才允许删除该数据卷

六、tmpfs mounts的基本使用(很少用,稍微了解就行)

如果在 Linux 上运行 Docker,那么还有第三种选择:tmpfs 挂载不会持久化到宿主机目的是为了避免写入数据到容器存储层还有一个方案

与卷和绑定挂载不同,tmpfs 挂载是临时的,只存留在主机内存中。当容器停止时,tmpfs 挂载将被删除,在那里写入的文件不会被持久化

6.1、tmpfs 挂载的局限性

  • 不同于卷和绑定挂载,不能在容器之间共享 tmpfs 挂载。
  • 这个功能只有在 Linux 上运行 Docker 时才可用。

6.2、–tmpfs 和 --mount 行为之间的差异

  • –tmpfs 标记不允许指定任何可配置选项。
  • –tmpfs 标记不能用于集群服务。对于集群服务,您必须使用 --mount。

6.3、在容器中使用 tmpfs 挂载

要在容器中使用 tmpfs 挂载, 请使用 --tmpfs 标记, 或者使用带有 type=tmpfs 和 destination 选项的 --mount 标记。没有用于 tmpfs 挂载的源(source)。

示例1:(–mount),在 Nginx 容器中的 /usr/share/nginx/html 创建一个 tmpfs 挂载

$ docker run -d \-it \--name tmptest \--mount type=tmpfs,destination=/usr/share/nginx/html \nginx:latest
$ docker exec -it tmptest /bin/bash
$ df -h

示例2:(–tmpfs)

$ docker run -d \-it \--name tmptest2 \--tmpfs /usr/share/nginx/html \nginx:latest

通过运行 docker inspect tmptest 来验证挂载是否是 tmpfs 挂载,查看 Mounts 部分:

$ docker inspect tmptest|grep -i -C3 Tmpfs


6.4、指定 tmpfs 选项

tmpfs 挂载允许两个配置选项,两个选项都不是必需的。 如果需要指定这些选项,则必须使用 --mount 标记,因为 --tmpfs 标记不支持。

tmpfs-size   tmpfs 挂载的大小(以字节为单位)。默认无限制。
tmpfs-mode  tmpfs 的八进制文件模式。例如,700 或 0770。默认为 1777 或全局可写。

示例:下面的示例将 tmpfs-mode 设置为 1770,因此在容器中它不是全局可读的。

$ docker run -d \-it \--name tmptest3 \--mount type=tmpfs,destination=/usr/share/nginx/html,tmpfs-mode=1770 \nginx:latest

Docker数据卷—Volumes相关推荐

  1. Docker容器的数据卷(volumes)

    目录 1.容器数据卷技术解决什么问题 docker可将应用和环境打包成一个镜像.容器是镜像的实例化. 我们的数据如果都在容器中,一旦容器删除,数据就会丢失. 数据卷技术可将容器产生的数据同步到本地,容 ...

  2. Docker 数据卷之进阶篇

    Docker 数据卷之进阶篇 原文:Docker 数据卷之进阶篇 笔者在<Docker 基础 : 数据管理>一文中介绍了 docker 数据卷(volume) 的基本用法.随着使用的深入, ...

  3. docker 数据卷 volume

    集群直接部署tomcat项目,可能项目在不同的服务器上,如何实现不同服务器上面的项目同步,可是使用docker数据卷的形式 首先我们来认识最为基础的docker数据卷 如何创建一个数据卷: 1.创建 ...

  4. Docker数据卷管理

    前言 docker数据卷 数据卷是目录或文件,不是块设备. 容器可以读写volume中的数据. volume数据可以持久化保存. docker提供了两种卷: bind mount 是将主机上的目录或文 ...

  5. Docker学习总结(68)—— Docker 数据卷相关知识总结

    前言 在生产环境中使用 Docker,要想实现数据的持久化(所谓 Docker 的数据持久化即数据不随着 Container 的结束而结束)或者需要在多个容器之间进行数据共享,需要将数据从宿主机挂载到 ...

  6. docker数据卷容器卷_如何删除Docker映像,容器和卷

    docker数据卷容器卷 Docker备忘单 (A Docker Cheat Sheet) 介绍 (Introduction) Docker makes it easy to wrap your ap ...

  7. Docker(七)--Docker数据卷管理及插件

    一.Docker 数据卷管理 在实际使用过程中,我们需要把容器和数据进行隔离,因为容器在使用过程中可能随时要进行销毁,但是数据要保留下来,所以我们要做数据的持久化. 为什么要用数据卷 docker分层 ...

  8. 【云原生】Docker数据卷及网络详细讲解

    前言 大家好,本文是对 Docker 数据卷及网络详细讲解,讲解了如何创建使用数据卷,以及如何使用 Docker network.希望对大家有所帮助~ 目录 前言 一.Docker 数据卷 1.1.数 ...

  9. Docker 基本操作 数据卷 -- docker 数据卷基本操作、挂载数据卷

    文章目录 1. docker 数据卷基本操作 1.1 容器与数据耦合的问题 1.2 数据卷介绍 1.3 数据卷的基本语法 1.4 创建一个数据卷,并查看数据卷在宿主机的目录位置 1.5 小结 2. 挂 ...

最新文章

  1. ajax静态页面实例,AJAX实例:Ajax实现静态页面分页
  2. boost::hana::reverse用法的测试程序
  3. java spring 配置词典_java之spring mvc之拦截器
  4. python 图片相似度算法比较_python 比较2张图片的相似度的方法示例
  5. 有一列数列,1,11,21,1211,111221,.........,
  6. mysql最多多少slave_MySQL5.7主从,单slave多master
  7. 1063 Set Similarity (25 分) set注意查询从1到q所以输入的时候也要从1到n
  8. java接收json数组转成字符串、对象转json、json字符串转list
  9. JSP+javabean实现购物车功能
  10. Vlookup实现多条件匹配
  11. 程序员如何准备简历以及面试的要求
  12. win11怎么看激活状态
  13. 图片怎么转文字?建议收藏这些方法
  14. 一篇小文入门 Python
  15. 新一代物联网商用全面铺开 NB-IoT擎起新智慧城市
  16. 微信分享服务器,微信分享的链接会被腾讯后台先访问
  17. 怎么转换视频格式,视频格式不符如何转换?
  18. 苹果手机热点总断开怎么办?
  19. 富甲天下3绝对完美版
  20. BOM出库,原来这么快

热门文章

  1. csgo显示无法更新服务器,csgo更新无法连接服务器
  2. springboot结合redis解决重复提交问题的实际应用
  3. WIFI共享精灵 2013 电脑共享wifi
  4. Lending Club贷款违约预测
  5. oracle 按天数 均值,oracle 按天数统计数据
  6. 【Codecs系列】HEVC标准(五):帧间预测技术及x265实现分析
  7. unity cardboard 导出
  8. Vue.js项目实战开发(4)- 必掌握知识点 - #博学谷IT学习技术支持#
  9. Selenium自动化测试框架基础操作
  10. 从程序员到产品经理再到自己创业的心路历程