简介
用户在使用Docker的过程中,往往需要能查看容器内应用产生的数据,或者需要把容器内的数据进行备份,甚至多个容器之间进行数据的共享,这必然涉及容器的数据管理操作。
容器中管理数据主要有两种方式:
1.数据卷(Data Volumes)
2.数据卷容器(Data Volume Dontainers)
本文将首先介绍如何在容器内创建数据卷,并且把本地的目录或文件挂载到容器内的数据卷中。接下来,会介绍如何使用数据卷容器在容器和主机、容器和容器之间共享数据,并实现数据的备份和恢复
数据卷
数据卷是一个供容器使用的特殊目录,位于容器中。可将宿主机的目录挂载到数据卷上,对数据卷的修改操作立刻可见,并且更新数据不会影响镜像,从而实现数据在宿主机与容器之间的迁移。数据卷的使用类似于Linux下对目录进行的mount操作。
docker cp 也是一种迁移
docker pull centos:7
#宿主机目录/var/www挂载到容器中的/datal。
#注意:宿主机本地目录的路径必须是使用绝对路径。如果路径不存在,Docker会自动创建相应的路径。
docker run -v /var/www:/data1 --name c1 -itd centos:7 /bin/bash
#-v选项可以在容器内创建数据卷
docker exec -it c1 bash #进容器
ls #查看目录是否存在
echo"this is test">/data1/abc.txt
exit #返回宿主机进行查看
cat /var/www/qwe.txt
我们就通过了这样几个步骤验证了将宿主机的目录挂载到容器的数据卷上,对数据卷的修改操作立刻可见,并且更新数据不会影响镜像,从而实现数据在宿主机与容器之间的迁移。
数据卷容器
#创建一个容器作为数据卷容器
docker run --name c2 -v /data1 -v /data2 -itd centos:7 /bin/bash
echo "this is test1" >/data1/qwe1.txt
echo "this is test2" >/data2/qwe2.txt
#使用--volumes-from 来挂载c2容器中的数据卷到新的容器
docker run -it --volumes-from c2 --name c3 centos:7 /bin/bash
cat /datal/qwe1.txt
cat /data2/qwe2.txt
如果需要在容器之间共享一些数据,最简单的方法就是使用数据卷容器。数据卷容器是一个普通的容器,专门提供数据卷给其他容器挂载使用。
容器互联(使用centos镜像)
容器互联是通过容器的名称在容器间建立一条专门的网络通信隧道。简单点说,就是会在源容器和接收容器之间建立一条隧道,接收容器可以看到源容器指定的信
#创建并运行源容器取名c4
docker run -itd -P --name c4 centos:7 /bin/bash
#创建并运行接收容器取名c4,使用--1ink选项指定连接容器以实现容器互联
docker run -itd -P --name c5 --link c4:c4 centos:7 /bin/bash #--1ink容器名:连接的别名
#进c5容器,ping c4
docker exec-it c11 bash
ping c4