加入收藏 | 设为首页 | 会员中心 | 我要投稿 核心网 (https://www.hxwgxz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程 > 正文

Docker 数据持久化的三种方案,你总能用到

发布时间:2019-09-05 18:32:49 所属栏目:编程 来源:Arking
导读:容器中的数据可以存储在容器层。但是将数据存放在容器层存在以下问题: 数据不是持久化。意思是如果容器删除了,这些数据也就没了 主机上的其它进程不方便访问这些数据 对这些数据的I/O会经过存储驱动,然后到达主机,引入了一层间接层,因此性能会有所下

当使用docker service create 启动Docker服务时,只支持--mount,不支持-v和--volume。并且每个服务容器使用它们各自的本地卷,因此如果使用本地(local)卷驱动,容器无法通过卷共享数据,但是一些卷驱动支持共享存储。Docker for AWS和Doocker for Azure都使用Cloundstor plugin支持持久存储

场景

  • 多个运行容器间共享数据
  • 当Docker主机不确保具有给定的目录或文件时。卷可以将容器运行时与Docker主机的配置解耦合
  • 备份、恢复、或将数据从一个Docker主机迁移到另一个Docker主机时

bind mount

主机中的文件或目录通过全路径被引用。在使用绑定挂载时,这些目录或文件不一定要已经存在。

如果使用这种方式将一个目录挂载到容器中一个存有文件或目录的目录中,这些文件或目录会被隐藏;如果主机中的文件或目录不存在,当使用--mount挂载时,Docker会报错,当使用-v--volume时,会在主机上创建目录

使用

挂载到容器:-v或—volume。如果是Docker17.06或更高:推荐使用—mount。(同 volumes)

  • -v--volume:由3个域组成,':'分隔
  1. 第一个域:对于命名卷,为卷名;匿名卷,则忽略,此时会创建匿名卷
  2. 第二个域:容器中的挂载点
  3. 第三个域:可选参数,由','隔开,如ro
  • --mount:由多个','隔开的键值对<key>=<value>组成:
  1. 挂载类型:key为type,value为bind、volume或tmpfs
  2. 挂载源:key为source或src,value为主机中文件或目录的路径
  3. 容器中的挂载点:key为destination、dst或target,value为容器中的路径
  4. 读写类型:value为readonly,没有key
  5. bind-propagation选项:key为bind-propagation,value为rprivate、private、rshared、shared、rslave或slave
  6. 一致性选项:value为consistent、delegated、cached。这个选项仅仅适用于Docker for Mac
  7. --mount不支持z和Z(这个不同于-v和—volume)

场景

(编辑:核心网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读