博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Docker 容器的数据管理
阅读量:5106 次
发布时间:2019-06-13

本文共 1249 字,大约阅读时间需要 4 分钟。

docker 容器的数据卷

什么是数据卷(DataVolume)

数据卷是经过特殊计的目录,可以绕过联合文件系统(UFS),为一个或多个容器提供访问。

数据卷设计的目的,在于数据的永久化,它完全独立与容器的生存周期,因此,Docker不会在容器删除时删除其挂载的数据卷,也不会存在类似的垃圾收集机制,对容器引用的数据卷进行处理。

docker数据卷是独立于容器,存在于宿主机Host里。数据卷可以是目录,也可以是文件。数据卷可以实现多个容器的数据共享和交换。

数据卷(DataVolume)的特点

  • 数据卷在容器启动时初始化,如果容器使用的铺像在挂载点包含了数据,这些
    数据会拷贝到新初始化的数据卷中。
  • 数据卷可以在容器之间共享和重用
  • 可以对数据卷里的内容直接进行修改
  • 数据卷的变化不会影响像的更新
  • 卷会一直存在,即使挂载数据卷的容器已经被删除

为容器添加数据卷

sudo docker run -v ~/containerdata:/data -it ubuntu/bin/bash

为数据卷添加访问权限

$dockerrun -v ~/datavolume:/data:ro -it ubuntu/bin/bash只读

使用Dockerfile构建包含数据卷的镜像

DockerfiIe指令:VOLUME["/data"]

创建的目录不能映射已存在的本地文件目录中,运行同样镜像所建的数据卷也是不同的。本地目录由docker自动创建。

docker 的数据卷容器

命名的容器挂载数据卷,其他容器通过挂载这个容器实现数据共享,挂载数据卷的容器,就叫做数据卷容器。

挂载数据卷容器的方法:

docker run --volumes-from [CONTAINERNAME]

简化inspect返回信息,只查看volume信息:

docker inspect --format="{
{.volumes}}" CONTAINER-NAME

即使删除了数据卷容器,挂载这个数据卷容器的容器仍然可以访问数据卷挂载目录,即数据卷容器只是一个配置信息的传递

docker rm -v CONTAINER_NAME连同volume一起删除(依旧可以访问,实质是指向本地目录)

docker 数据卷的备份和还原

数据备份方法

docker run --volumes-from [container name] -v $(pwd):/backup ubuntu

tar cvf /backup/backup.tar [container data volume]

数据换原方法

docker run --volumes-from [container name] -v$(pwd):/backup ubuntu

tar xvf /backup/backup.tar [container data volume]

转载于:https://www.cnblogs.com/boxker/p/10631429.html

你可能感兴趣的文章
iframe跨域与session失效问题
查看>>
aboutMe
查看>>
【Debug】IAR在线调试时报错,Warning: Stack pointer is setup to incorrect alignmentStack,芯片使用STM32F103ZET6...
查看>>
一句话说清分布式锁,进程锁,线程锁
查看>>
Hash和Bloom Filter
查看>>
SQL Server获取月度列表
查看>>
python常用函数
查看>>
python 描点画圆
查看>>
FastDFS使用
查看>>
服务器解析请求的基本原理
查看>>
pycharm 如何设置方法调用字体颜色
查看>>
VUE源码解析心得
查看>>
[HDU3683 Gomoku]
查看>>
【工具相关】iOS-Reveal的使用
查看>>
整体二分——[Poi2011]Meteors
查看>>
数据库3
查看>>
delphi之事件
查看>>
windows server 2008 r2 安装
查看>>
存储分类
查看>>
下一代操作系统与软件
查看>>