在docker的数据管理中,有两个概念:

1、数据卷

  数据卷是一个可供容器使用的特殊目录,它绕过文件系统,可以提供很多有用的特性:

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

    1.2 对数据卷的修改会立刻生效

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

    1.4 卷会一直存在,直到没有容器使用

  数据卷的使用,类似linux系统中的mount操作。

2、数据卷容器

  数据卷容器,其实就是一个普通的容器,只不过是挂载一个数据卷目录,供其他容器共享和持续更新数据来使用。

下面介绍数据卷以及数据卷容器的使用示例:

一、数据卷:

在运行docker run的时候,使用-v参数可以挂载数据卷,多次使用-v 可以挂载多个数据卷

#docker run -dit --name datatest -v /home/linkface/dockerdir:/data nginx:1.7 /bin/bash

上面的命令是运行一个容器datatest,将宿主机的dockerdir目录,挂载到容器中的/data/目录,在/data/中创建修改文件,本地的dockerdir目录可以查看到。

#cd /data
#touch 123
#ls -l
-rw-r--r-- 1 root root 0 Nov  7 07:28 123

发现我们的宿主机也同时有了这个文件,这个在做测试的时候非常方便,可以将本地代码或者测试文件通过数据卷映射到容器内。

***本地路径一定要使用绝对路径,容器路径如果没有,会自动创建。***

上面是通过目录的方式挂载,其实也可以挂载文件:

#docker run --rm -dit -v ~/.bash_history:/.bash_history nginx:1.7 /bin/bash

不过直接挂载文件不推荐使用,因为一旦使用vi,vim,sed等工具编辑修改文件,有可能导致inode改变,导致报错,故建议挂载目录。

二、数据卷容器:

数据卷容器,顾名思义,就是启动一个容器,来单独当做数据卷来使用,数据卷容器的特点是方便在容器之间共享和更新数据。

#docker run -dit --name dbdata -v /home/linkface/dockerdir:/dbdata centos /bin/bash

创建一个数据卷容器,挂载本地dockerdir到容器的dbdata

接下来,我们创建新的容器,但是使用dbdata容器的dbdata目录作为数据卷:

挂载数据卷容器内的数据卷,要使用--volumes-from 参数

#docker run -dit --name db1 --volumes-from dbdata nginx:1.7 /bin/bash
#docker run -dit --name db2 --volumes-from dbdata nginx:1.7 /bin/bash

依次查看各个容器的数据卷:

先查看第一个创建的数据卷容器的数据卷情况:

新建的两台db1跟db2的:

可以看出来是共用的,我们新建一个文件试试:

去其他容器看一下:

这样就做到了容器之间的数据共享,以及持续更新。

如果删除了挂载的容器,数据卷并不会自动删除,如果要删除,需要在最后一个还挂载着他的容器时使用docker rm -v 命令,来删除指定同时删除关联的容器。

三、利用数据卷容器迁移数据

  3.1备份

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

  

#docker run --volumes-from dbdata -v $(pwd):/backup centos tar cvf /backup/backup.tar /dbdata
/dbdata/
/dbdata/123
/dbdata/mydata
tar: Removing leading `/' from member name

解释一下上面的命令:

运行一个容器,挂载dbdata的数据卷,并且将本地的当前目录,映射到容器的/backup ,然后执行压缩命令,将dbdata,打包到容器的/backup/下,也就是映射的本地目录。

backup.tar就是我们刚刚从dbdata上备份下来的数据。

  3.2 恢复

  如果要恢复数据到一个容器,跟刚才的命令类似:

  首先,创建并运行一个容器:

  我们只是使用-v 在容器内等于共享了一个dbdata,但是实际上没有将它映射到任何目录。

#docker run -dit --name db3  -v /dbdata centos /bin/bash

  开始恢复:

#docker run --volumes-from db3 -v $(pwd):/backup centos tar xvf /backup/backup.tar

解释一下上面的命令:

创建并运行一个容器,挂载db3的dbdata,并且将本地当前目录,映射成容器内的/backup目录,然后解压,此时,数据将被解压到db3的dbdata中。

  

ubuntu-docker入门到放弃(六)数据管理的更多相关文章

  1. Docker入门教程(六)另外的15个Docker命令

    Docker入门教程(六)另外的15个Docker命令 [编者的话]DockerOne组织翻译了Flux7的Docker入门教程,本文是系列入门教程的第六篇,继续介绍Docker命令.之前的第二篇文章 ...

  2. Ubuntu菜鸟入门(十六)—— 安装视频播放器vlc

    sudo add-apt-repository ppa:videolan/master-daily sudo apt-get update sudo apt-get install vlc Ubunt ...

  3. docker入门到放弃

    1.容器简介 Docker是一个开源的应用容器引擎,使用Go语言开发,基于Linux内核的cgroup,namespace,Union FS等技术,对应用进程进行封装隔离,并且独立于宿主机与其他进程, ...

  4. MyBatis从入门到放弃六:延迟加载、一级缓存、二级缓存

    前言 使用ORM框架我们更多的是使用其查询功能,那么查询海量数据则又离不开性能,那么这篇中我们就看下mybatis高级应用之延迟加载.一级缓存.二级缓存.使用时需要注意延迟加载必须使用resultMa ...

  5. hive从入门到放弃(六)——常用文件存储格式

    hive 存储格式有很多,但常用的一般是 TextFile.ORC.Parquet 格式,在我们单位最多的也是这三种 hive 默认的文件存储格式是 TextFile. 除 TextFile 外的其他 ...

  6. Docker入门

    -----------------------------------------Docker入门教程(一)介绍Docker入门教程(二)命令Docker入门教程(三)DockerFileDocker ...

  7. Docker 入门 第六部分:部署app

    目录 Docker 入门 第六部分:部署app 先决条件 介绍 选择一个选项 Docker CE(Cloud provider) Enterprise(Cloud provider)这里不做介绍 En ...

  8. 【实战】Docker 入门实战一:ubuntu 和 centos 安装Docker

    Docker是什么 Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从Apache2.0协议开源.Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发布 ...

  9. Docker入门(六):Stacks

    这个<Docker入门系列>文档,是根据Docker官网(https://docs.docker.com)的帮助文档大致翻译而成.主要是作为个人学习记录.有错误的地方,Robin欢迎大家指 ...

  10. DOCKER 从入门到放弃(二)

    搜索镜像 从docker官方镜像仓库搜索镜像 docker search [OPTIONS] TERM OPTIONS: --automated :只显示自动创建的镜像,默认值为fasle --fil ...

随机推荐

  1. 标准正态分布表(scipy.stats)

    0. 标准正态分布表与常用值 Z-score 是非标准正态分布标准化后的 x即 z=x−μσ" role="presentation">z=x−μσz=x−μσ 表 ...

  2. 使用Git来撤销修改

    首先进入一个有Git管理的文件夹下: 当我们在文件编写过程中出现了一个错误怎么办呢?如下: 但是此时你并没有将文件提交缓冲区,你可以去手动打卡文件删除这个错误. 当然你也可以查看一下状态: 发现这个文 ...

  3. ss server端配置

    关于ss server的配置,可以参考一个网址 关于服务器的购买可以上VIRMACH购买 和本地安装ss类似,首先安装ss,pip install shadowsocks 配置服务器参数,vim /e ...

  4. while循环中出现ssh导致读取文件错误

    while read line do ...... ssh ... done < $file 使用上面包含ssh命令的while循环,ssh命令将$file内容全部吞噬,导致只处理完一行即退出: ...

  5. Arcgis API本地化

    ①将API文件夹复制到该目录下C:\Program Files\ArcGIS\Server\framework\runtime\tomcat\webapps ②打开API文件夹中的init.js文件( ...

  6. @PropertySouce注解

    1.@ProtertySource @PropertySouce是spring3.1开始引入的基于java config的注解. 通过@PropertySource注解将properties配置文件中 ...

  7. sqlyog数据库管理软件下载

    下载安装包 一路next 链接:https://pan.baidu.com/s/1tdIwtYEW11MNWk--Hqd3dw 提取码:0ffp 复制这段内容后打开百度网盘手机App,操作更方便哦 然 ...

  8. 数据库连接池——Druid

    使用步骤: 1.导包,durid1.0.9 jar包 2.定义配置文件,properties文件,名字任意位置也任意, 3.加载文件 4.获得数据库连接池对象  通过DuridDataSourceFa ...

  9. svelte 构建快速web 应用的工具

    svelte 和angular vue reat 类似,都是方便快速的创建用户界面,最大不同的地方是svelte 转换你的app 是在构建时,而不是运行时,所以好处就是不用花费太多的操作在,框架的 抽 ...

  10. 普林斯顿数学指南(第三卷) (Timothy Gowers 著)

    第V部分 定理与问题 V.1 ABC猜想 V.2 阿蒂亚-辛格指标定理 V.3 巴拿赫-塔尔斯基悖论 V.4 Birch-Swinnerton-Dyer 猜想 V.5 卡尔松定理 V.6 中心极限定理 ...