上节讲到当容器运行期间产生的数据是不会在写镜像里面的,重新用此镜像启动新的容器就会初始化镜像,会加一个全新的读写入层来保存数据。如果想做到数据持久化,Docker提供数据卷(Data volume)或者数据容器卷来解决问题,另外还可以通过commit提交一个新的镜像来保存产生的数据。那么,来一一看下各自的使用方法。

一、数据卷

数据卷特性:

  • 可以绕过UFS文件系统,为一个或多个容器提供访问。

  • 完全独立于容器的生存周期,因此不会在删除容器时删除其挂在的数据卷。

数据卷特点:

  • 数据卷在容器启动初始化时,如果容器使用的镜像在挂载点包含了数据,这些数据会拷贝到新初始化的数据卷中。

  • 数据卷可以在容器直接共享和重用。

  • 可以直接对数据卷里的内容进行修改。

  • 数据卷的变化不会影响镜像的更新。

  • 卷会一直存在,即使挂载数据卷的容器已经删除。

1.数据卷使用

创建并挂载数据卷:

$ sudo docker run -itd --name ubuntu_test1 -v /container_data:/data ubuntu

注:container_data为宿主机目录,/data是容器中目录,目录不存在会自动创建

$ sudo docker inspect ubuntu_test1

"Mounts": [

{

"Source": "/container_data",

"Destination": "/data",

"Mode": "",

"RW": true

}

],

可以看到已经挂载成功,并且容器对这个目录具有读写权限。

测试:

$ cd container_data

$ sudo touch test.txt

$  sudo docker exec ubuntu_test1 ls /data

test.txt

在宿主机目录创建的文件,同样在容器内看到。

2.删除容器,数据会一同删除吗?

$ sudo docker stop ubuntu_test1

$ sudo docker rm ubuntu_test1

$ ls container_data

test.txt

看到宿主机上数据卷目录里的文件并没有发生变化,说明删除容器不会影响数据卷。

3.重新启动一个容器,同样挂载这个数据卷试试

$ sudo docker run -itd --name ubuntu_test2 -v /container_data:/data ubuntu

$  sudo docker exec ubuntu_test1 ls /data

test.txt

文件依然存在,说明初始化时将数据拷贝到了容器中。

3.再启动一个容器,还将数据卷挂载到这里

$ sudo docker run -itd --name ubuntu_test3 -v /container_data:/data ubuntu

$  sudo docker exec ubuntu_test1 ls /data

test.txt

同样可以看到数据,说明数据卷可以共享多个容器使用。

二、 容器 数据卷

将一个正常的容器作为数据卷,让其他容器通过挂载这个容器实现数据共享。

注意:数据卷容器会降低I/O性能。

1.容器数据卷使用

创建一个dvdata的数据卷容器:

$ sudo docker run -itd -v /data --name dvdata ubuntu

注:/data是数据卷容器内共享的目录

在其他容器中挂载dvdata容器的数据卷:

$ sudo docker run -itd --name web1 --volumes-from dbdata ubuntu

$  sudo docker run -itd --name web2 --volumes-from dbdata ubuntu

分别进入web1、web2容器中,会有一个/data目录,在web1里的/data目录创建文件,web2也能看的到。

总结: 如果删除dvdata、web1、web2,时,数据卷并不会被自动删除。如果想删除需在删除最后一个挂载着它的容器时使用docker rm -v 命令来指定删除关联的容器。

博客地址: http://lizhenliang.blog.51cto.com

三、commit命令使用

commit命令作用是将已存在容器中的镜像和修改内容提交为一个新的镜像,通过这个方式同样能保存读写层内容。

1.启动一个新容器,并在容器/opt目录下创建test.txt文件

$ sudo docker run -itd --name web ubuntu

$ sudo docker exec web touch /opt/test.txt

$ sudo docker exec web ls /opt

test.txt

2.提交一个新的镜像

$ sudo docker commit web web:v2

$ sudo docker images

3.成功提交一个新的镜像,用这个新的镜像启动一个容器,看是否创建的文件存在

$ sudo docker run -itd --name web_v2 web:v2

$ sudo docker exec web_v2 ls /opt

test.txt

总结: commit命令同样能实现保存读写层数据,但不适于做数据持久化

四、数据卷容器备份和还原

备份:

$ sudo docker run --volumes-from dvdata -v /container_backup:/backup ubuntu tar cvf /backup/backup.tar /data

说明:先创建一个临时容器,并挂载dvdata容器数据卷,再挂载数据卷/container_backup目录到容器/bakcup,在容器中执行备份/data目录到/backup,也就是备份到宿主机/container_backup目录。

恢复:

#先创建一个数据卷容器

$ sudo docker run -v /data --name dvdata2 ubuntu

注意:这个数据卷目录名要与备份的一样

#再将备份文件恢复到这个数据卷容器

$ sudo docker run --volumes-from dvdata2 -v /container_backup:/backup ubuntu tar xvf /backup/backup.tar

#最后启动一个容器挂载验证/data目录数据恢复成功

$ sudo docker run -itd --volumes-from dvdata2 --name web_recover ubuntu

五、迁移容器和镜像

export与import命令使用:

#export导出容器会丢失历史记录和元数据,类似与快照

先创建测试容器:

$ sudo docker exec web touch /opt/test.txt

$ sudo docker exec web ls /opt

test.txt

执行导出:

$ sudo docker export web > web.tar

执行导入:

$ cat web.tar | sudo docker import - web:v2

$ sudo docker images

$ sudo docker run -itd --name web_v2 web:v2 /bin/bash

#启动这个镜像要加/bin/bash,否则报错Error response from daemon: No command specified

$ sudo docker exec web_v2 ls /opt

test.txt

总结: 通过export命令也可以将容器里的数据保存,并可以迁移到别的docker主机

save与load命令使用:

#一般用于迁移镜像到别处

导出:

$ sudo docker save web > web.tar

导入:

$ sudo docker load < ubuntu.tar

注:不会丢弃历史记录和元数据,并可以回滚版本。启动不用加/bin/bash

来自: http://lizhenliang.blog.51cto.com/7876557/1730892

Docker数据持久化与容器迁移的更多相关文章

  1. Docker数据持久化及实战(Nginx+Spring Boot项目+MySQL)

    Docker数据持久化: Volume: (1)创建mysql数据库的container docker run -d --name mysql01 -e MYSQL_ROOT_PASSWORD= my ...

  2. docker数据持久化/共享---volume,bind-mount,tmpfs-mount

    一.将Docker数据挂载到容器 在Docker中,要想实现数据的持久化(所谓Docker的数据持久化即数据不随着Container的结束而结束),需要将数据从宿主机挂载到容器中.目前Docker提供 ...

  3. docker数据持久化

    转载/参考: https://www.jianshu.com/p/ef0f24fd0674 Docker的数据持久化主要有两种方式: bind mount docker managed volume ...

  4. Docker 数据卷与容器互联

    Docker是基于Go语言实现的开源容器项目,Docker让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化.容器是完全使用沙箱机制, ...

  5. Docker | 数据持久化与数据共享

    数据持久化(安装MySQL) 参考另一篇Docker安装mysql: https://www.cnblogs.com/all-smile/p/16778376.html MySQL的数据持久化问题 # ...

  6. `docker数据持久化volume和bind mounts两种方式

    将数据从宿主机到容器的三种方式: ,volumes:docker管理宿主机文件系统的一部分(/var/lib/docker/volumes)保存数据的最佳方式 ,bind mounts 将宿主机上的任 ...

  7. 22. docker 数据持久化 Data Volume

    1 . 使用场景 在docker 容器被删除的时候  希望数据不丢失 2 . Volume 的使用 * 注意 在 mysql 的 Dockerfile 内 定义了 VOLUME ["var/ ...

  8. 23. docker 数据持久化 bind mounting

    1. bind mounting 和 data volume 的区别 data volume 需要在 Dockerfile 定义 Volume bind mounting 只需要 -v 指明 容器外部 ...

  9. docker 数据持久化

    confluence #!/bin/bash docker run \ --name confluence \ --volume "$PWD/data/opt":/opt \ -- ...

随机推荐

  1. 【转】Java并发编程:volatile关键字解析

    转自:http://www.importnew.com/18126.html#comment-487304 volatile这个关键字可能很多朋友都听说过,或许也都用过.在Java 5之前,它是一个备 ...

  2. linux fdisk命令使用

    fdisk 对硬盘及分区的操作,进入fdisk 对硬盘操作阶段 我们可以对硬盘进行分区操作,前提是您把fdisk -l 弄明白了:通过fdisk -l ,我们能找出机器中所有硬盘个数及设备名称:比如上 ...

  3. java并发编程资料

    并发这玩意很有用,把自己在网上看过觉得总结的很好的资料分享出来.猛击下面的地址查看吧 java并发编程:线程池的使用说明 java并发编程系列文章 Java并发性和多线程专题 并发工具类 Java 7 ...

  4. windows常用端口对应表

    端口概念 在网络技术中,端口(Port)大致有两种意思:一是物理意义上的端口,比如,ADSL Modem.集线器.交换机.路由器用于连接其他网络设备的接口,如RJ-45端口.SC端口等等.二是逻辑意义 ...

  5. WPF -Enum的三种绑定方法

    一.使用ObjectDataProvider <Window xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentat ...

  6. java报表工具FineReport常用函数的用法总结(文本和日期函数)

    文本函数 CHAR CHAR(number):根据指定数字返回对应的字符.CHAR函数可将计算机其他类型的数字代码转换为字符. Number:用于指定字符的数字,介于1Number:用于指定字符的数字 ...

  7. 谈谈Java中的ThreadLocal

    什么是ThreadLocal ThreadLocal一般称为线程本地变量,它是一种特殊的线程绑定机制,将变量与线程绑定在一起,为每一个线程维护一个独立的变量副本.通过ThreadLocal可以将对象的 ...

  8. struts2的拦截器(Interceptor)与过滤器(Filter)

    一.拦截器与过滤器的区别: 1.filter基于回调函数,我们需要实现的filter接口中doFilter方法就是回调函数,而interceptor则基于Java本身的反射机制,这是两者最本质的区别. ...

  9. Windows+Linux----打造和谐的开发环境

    其实Windows和Linux并非水火不容,相反,我觉得,如果将二者结合起来,取长补短,便可打造一个华丽.实用的开发环境. 吾以为,不会用linux的人,不能称为一个程序猿,但是一味觉得Linux很吊 ...

  10. [转载]一张图看懂开源许可协议,开源许可证GPL、BSD、MIT、Mozilla、Apache和LGPL的区别

    本文转载自:http://blog.csdn.net/testcs_dn/article/details/38496107 开源许可证GPL.BSD.MIT.Mozilla.Apache和LGPL的区 ...