跟我一起学docker--数据管理

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了跟我一起学docker--数据管理相关的知识,希望对你有一定的参考价值。

1.数据卷

数据卷是一个可供容器使用的特殊目录,有如下特性:

数据卷可以在容器之间共享和重用

数据卷修改会立即生效

数据卷的更新不会影响镜像

如果有容器使用数据卷,该卷会一直存在

准备工作:

    创建一个目录,并在目录里面创建文件,文件内写入内容。

技术分享图片

在容器内创建数据卷

在使用docker run的命令时,使用 -v 标记可以在容器内创建一个数据卷,并且可以指定挂在一个本地已有的目录到容器中作为数据卷:

docker run -d --name app1-it -v ${PWD}/webapp:/root/webapp ubuntu bash

通过目录跟容器内建立了一层关系,数据卷发生变化后,容器内和容器外都会随之发生改变。例如容器挂载一个文件,当容器挂了后,文件不会丢失。

注意:默认挂载的数据卷的权限是rw(可读写),如果要求ro(只读),则需要加上对应的ro参数,命令可改为:

docker run -d --name app1-it -v ${PWD}/webapp:/root/webapp:ro ubuntu bash

下面我们一起来操作一下:

    创建webapp目录,在目录下新建文件file,并在文件file中写入“this is a file”。

技术分享图片

    echo ${PWD} 命令标识当前目录。

技术分享图片

    创建启动app1容器并挂载数据卷

技术分享图片

    进入容器找到root目录可查看到已挂载的数据卷。

技术分享图片

    数据卷目录与容器内目录有映射关系,所以不管是在容器内部修改数据卷还是在外部修改数据卷,相对应的数据卷都会发生改变。

技术分享图片

    只读的演示

技术分享图片

2.数据卷容器

数据卷容器用于用户需要在容器间共享一些持续更新的数据,数据卷容器专门提供数据卷供其它容器挂载使用。

Example:

创建数据卷容器db1

docker run -d --name db1 -v/dbdata -ti ubuntu bash

创建容器db2与db1共享dbdata的数据

docker run -d --name db2 --volumes-from db1 -ti ubuntu bash

    在容器db1和容器db2任意一个容器修改dbdata的内容,在两个容器内均生效

数据卷容器的删除:

    如果删除了挂载的容器,数据卷并不会被自动删除,如果要删除一个数据卷,必须在删除最后一个还挂载它的容器时显示使用docker rm -v 命令指定同时删除关联的容器。在下图可看到即使删除aatest,bbtest中仍然有fileA文件。

    在aatest中创建了文件fileA,bbtest可以看到fileA,删除aatest容器后,fileA在bbtest中还可以看到。

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

备份:

使用下面的命令来备份dbdata数据卷容器内的数据卷:

docker run --volumes-from dbdata -v ${PWD}:/backup --name worker ubuntu ar cvf /backup/backup.tar/dbdata

说明:

    利用ubuntu镜像创建一个容器worker。使用--volumes-from dbdata参数来让worker容器挂载dbdata的数据卷;使用${pwd}:/backup参数来挂载本地目录到worker容器的/backup目录。

   worker启动后,使用tar命令将/dbdata下的内容备份为容器内的/backup/backup.tar。

    创建dbdata数据卷容器并写入文件:fileA、fileB、fileC

    执行备份命令创建备份tar包:

恢复:

    如果恢复数据到一个容器,可以参照下面的操作。首先创建一个带有数据卷的容器dbdata2:

    docker run -d -v /dbdata--name dbdata2 ubuntu /bin/bash

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

    docker run --volumes-from dbdata2 -v ${pwd}:/backup ubuntu tar xvf /backup/backup.tar


以上是关于跟我一起学docker--数据管理的主要内容,如果未能解决你的问题,请参考以下文章

跟我一起学docker(16)--单节点mesos集群

跟我一起学docker--网络

跟我一起学docker--镜像的常用操作

跟我一起学docker--Dockerfile

跟我一起学docker(11)--jenkins+github+Docker

跟我一起学docker(11)--jenkins+github+Docker