生产环境中使用docker的过程中,往往需要对数据进行持久化,或者需要在多个容器之间进行数据共享。
容器中管理数据主要有两种方式:
数据卷(Date Volumes):容器内数据直接映射到本地环境
数据卷容器(Date Volumes Containers):使用特定容器维护数据卷

1.数据卷

数据卷是一个可供容器使用的特殊目录,它将主机操作系统目录直接映射进容器,类似于Linux的mount操作
数据卷有许多有用的特性:

  • 数据卷可以在容器之间共享和重用,容器间传递数据会变得高效简单
  • 对数据卷内数据的修改会立马生效,无论是容器内的操作还是本地操作
  • 对数据卷的更新不会影响镜像,解耦了应用和数据
  • 卷会一直存在,直到没有容器使用,可以安全的卸载它

一般对数据卷的操作有以下三种方式:

(1)在容器内创建一个数据卷

在使用docker run或者docker create创建一个容器的时候,可以使用-v参数在容器内创建一个数据卷。
多次重复使用-v参数可以创建多个数据卷。

创建容器con_test004,并创建数据卷date_test:

启动容器:

进入容器查看数据卷:

(2)挂载一个主机目录作为数据卷

在使用docker run或者docker create创建一个容器的时候,可以使用-v参数指定挂载一个本地已有的目录到容器中去作为数据卷。

在本地创建一个目录:

创建容器con_test005,并将date目录挂载到容器中:

Docker挂载数据卷的默认权限时读写(rw),用户也可以通过ro指定为只读。

注意在挂载的时候都要使用绝对路径。否则会自动创建。

(3)挂载一个本地主机文件作为数据卷

-v也可以从主机挂载单个文件到容器中作为数据卷。
在本地创建一个文件:

创建一个新的容器并进行挂载:

进入容器,该文件已经存在:

不推荐直接挂载文件到容器内,也许会有意外的麻烦。

2.数据卷容器

如果用户需要在多个容器之间共享一些持续更新的数据,最简单的方式是使用数据卷容器。
数据卷容器也是一个容器,但是它的目的是专门用来提供数据卷供其它容器挂载。

创建一个数据卷容器dbdata,并在其中创建一个数据卷挂载到/dbdata:

在其它容器使用--volumes-from来挂载dbdata容器中的数据卷。
下面创建容器db1和db2,并且将dbdata容器中的数据卷挂载。
需要注意的是,-volumes-from会自动找到数据卷容器中的挂载卷,并将其标记

创建db1:

创建db2:

三个容器中任何一个容器在挂载卷下写入内容,其它容器都会看到。

在dbdata中创建一个文件,并写入内容:

查看db1和db2,发现数据已经同步:

可以多次使用--volumes-from参数来从多个容器挂载多个数据卷。还可以从其他已经挂载了容器卷的容器来挂载数据卷。

注意在使用--volumes-from参数所挂载数据卷的容器自身并不需要保持运行状态

如果删除了db3,发现db4依然能够同部dbdata的数据,说明它还是绑在dbdata这个容器上面。
删除db2,没有任何影响。
如果关闭dbdata数据卷容器,并不会影响数据的共享。
如果删除dbdata数据库容器,也不会影响数据的共享,说明数据卷依然存在。
如果想要删除一个数据卷,必须在删除最后一个还挂载着它的容器时显式使用docker rm -v来指定同时删除关联容器。

3.利用数据卷容器来移动数据

可以利用数据卷容器对其中的数据进行备份、恢复,以实现数据的迁移。

(1)备份

现在要将db1的dbdata备份到宿主机的data目录下。

过程如下:

  dockers run -it --name worker docker.io/centos  创建一个容器worker
  --volumes-from db1  让worker来挂载dbdata数据卷
  -v /data:/backup    挂载本地的data目录到worker容器的backup目录
  tar cvf /backup/backup.tar /dbdata  容器启动后,将dbdata下面的内容备份为容器内的/backup/backup.tar,即宿主机当前目录下下的backup.tar

(2)恢复

如果要将数据恢复到一个容器,有如下步骤:

首先创建一个带有数据卷的容器dbdata2:

docker run -v /dbdata --name dbdata2 ubuntu /bin/bash  #这个容器就是一个数据卷容器

然后创建另一个新的容器,挂载dbdata2的容器,并使用untar解压备份文件到所挂载的容器卷中:

docker run --volumes-from dbdata2 -v $(pwd):/backup busybox tar xvf

docker——数据管理的更多相关文章

  1. Docker数据管理(四)

    Docker数据管理 Docker数据分为两种: 数据卷 -v /data -v src:dst 数据卷容器 --volumes-from 数据卷 案例1:我们创建一个容器,起名叫nginx-volu ...

  2. Docker数据管理

    用户在使用Docker的过程中,往往需要能查看容器内应用产生的数据,或者需要把容器内的数据进行备份,甚至多个容器之间进行数据共享,这必然涉及到Docker的数据管理. 容器中管理数据主要有两种方式: ...

  3. Docker系统七:Docker数据管理

    Docker的数据管理 I. 基本概念 Docker容器一旦删除,其相关的rootf文件系统就会被删除,其容器内的数据将一并删除,为了保存相关数据,Docker提出了数据卷的概念. II. 数据卷 D ...

  4. Docker数据管理(五)

    一.什么是数据卷 生成环境中使用docker的过程中,往往需要对数据进行持久化,或者需要多个容器之间进行数据共享,这个就涉及到了容器数据管理 容器中管理数据主要有两种方式: 数据卷:容器内数据之间映射 ...

  5. Docker数据管理(数据卷&数据卷容器)

    生产环境中使用Docker的过程中,往往需要对数据进行持久化,或者需要在多个容器之间进行数据共享,这必然涉及容器的数据管理操作. 容器中管理数据主要有两种方式: 数据卷(Data Volumes):容 ...

  6. Docker实战(四)之Docker数据管理

    在生产环境中使用Docker的过程中,往往需要对数据进行持久化,或者需要在多个容器之间进行数据共享,这必然涉及到容器的数据管理操作. 容器中管理数据主要有两种形式: 数据卷:容器内数据直接映射到本地主 ...

  7. 【Docker】第五篇 Docker 数据管理

    一.基本介绍 数据管理的原因:Docker中的容器一旦删除,容器本身的rootfs文件系统就会被删除,容器中的所有数据就会被删除.为了对一些需要持久化的数据,不随容器删除而删除,所以我们可以通过多个容 ...

  8. <Docker学习>5. docker数据管理

    当我们创建了一个tomcat容器,如何简单部署一个web应用?如何将war包放入到容器中?也就是说怎么样把文件从宿主机中 "放入" 到容器中? docker cp命令可以将宿主机本 ...

  9. docker数据管理(2)

    一.docker存储资源类型 docker两种存储资源类型 用户在使用 Docker 的过程中,势必需要查看容器内应用产生的数据,或者需要将容器内数据进行备份,甚至多个容器之间进行数据共享,这必然会涉 ...

  10. 六、【Docker笔记】Docker数据管理

    前几节我们介绍了Docker的基本使用和三大核心概念,那么我们在使用Docker的过程中,Docker中必然产生了大量的数据,对于这些数据我们需要查看或者对这些数据进行一个备份,也有可能容器之间的数据 ...

随机推荐

  1. 如果想要跨平台,在file类下有separtor(),返回锁出平台的文件分隔符

    对于命令:File f2=new file(“d:\\abc\\789\\1.txt”) 这个命令不具备跨平台性,因为不同的OS的文件系统很不相同. 如果想要跨平台,在file类下有separtor( ...

  2. fzu 1330:Center of Gravity(计算几何,求扇形重心)

    Problem 1330 Center of Gravity Accept: 443    Submit: 830Time Limit: 1000 mSec    Memory Limit : 327 ...

  3. css属性image-redering详解

    What? image-rendering作为现阶段还处于实验性质中的css属性,他的作用是在浏览器对图片进行比例缩放时,设置其缩放使用的算法,从而来得到我们最终想要的图片结果.而且这个属性可以应用于 ...

  4. Struts2_day02--封装数据到集合里面

    封装数据到集合里面 封装数据到List集合 第一步 在action声明List 第二步 生成list变量的set和get方法 第三步 在表单输入项里面写表达式 封装数据到Map集合 第一步 声明map ...

  5. centos中调整tmpfs分区的大小

    tmpfs是Linux/Unix系统上的一种基于内存的文件系统.tmpfs可以使用系统的内存或swap分区来存储文件.由此可见,tmpfs主要存储暂存的文件. tmpfs默认的大小是RM的一半,假如你 ...

  6. 【BZOJ3809/3236】Gty的二逼妹子序列 [Ahoi2013]作业 莫队算法+分块

    [BZOJ3809]Gty的二逼妹子序列 Description Autumn和Bakser又在研究Gty的妹子序列了!但他们遇到了一个难题. 对于一段妹子们,他们想让你帮忙求出这之内美丽度∈[a,b ...

  7. springMVC问题

    网站中springmvc.xml配置: <bean id="viewResolver" class="org.springframework.web.servlet ...

  8. angular4 常用pipe管道

    angular中的pipe是用来对输入的数据进行处理,如大小写转换.数值和日期格式化等. 常用的pipe有 1. 大小写转换 <p>{{str | uppercase}}</p> ...

  9. CH5101 LCIS【线性dp】

    5101 LCIS 0x50「动态规划」例题 描述 熊大妈的奶牛在小沐沐的熏陶下开始研究信息题目.小沐沐先让奶牛研究了最长上升子序列,再让他们研究了最长公共子序列,现在又让他们研究最长公共上升子序列了 ...

  10. SignalR循序渐进(二)泛型Hub

    接上一篇,文章末尾抛出了2个问题: 能不能让客户端声明一个强类型的方法列表呢?这样首先不容易写错. 同样的,能不能让服务端声明一个强类型的方法列表给客户端调用呢? 如果要让客户端的方法以强类型出现在服 ...