Docker容器---数据卷 数据容器
- 一、数据卷概述
- 1、数据卷
- 2、数据卷原理
- 3、数据卷作用
- 二、数据卷容器
- 1、数据卷容器作用
- 2、创建数据卷容器
- 三、容器互联
- 1、创建并运行源容器取名web1
- 2、创建并运行接收容器取名web2
一、数据卷概述
管理 Docker 容器中数据主要有两种方式:数据卷(Data Volumes)和数据卷容器(DataVolumes Containers)。
1、数据卷
数据卷是一个供容器使用的特殊目录,位于容器中。可将宿主机的目录挂载到数据卷上,对数据卷的修改操作立刻可见,并且更新数据不会影响镜像,从而实现数据在宿主机与容器之间的迁移。数据卷的使用类似于 Linux 下对目录进行的 mount 操作。
2、数据卷原理
将容器内部的配置文件目录,挂载到宿主机指定目录下
数据卷默认会一直存在,即使容器被删除。
宿主机和容器是两个不同的名称空间,如果想进行连接需要用ssh,exec和attch也类似于ssh这种方式登录。
在企业中ssh这种登陆方式会比较危险,安全漏洞很大,尽量减少ssh这种,杜绝了频繁使用exec。
因此使用数据卷的方式把容器内部的文件目录挂载到宿主机指定目录下进行修改,当容器里的文件频繁需要修改时不需要登陆进去,直接使用数据卷方式在宿主机指定的目录下进行修改即可,方便又安全。
3、数据卷作用
数据卷是一个供容器使用的特殊目录,位于容器中。可将宿主机的目录挂载到数据卷上,对数据卷的修改操作立刻可见,并且更新数据不会影响镜像,从而实现数据在宿主机与容器之间的迁移。数据卷的使用类似于Linux下对目录进行的 mount操作。
例子
创建两个容器,指定挂载点,并在宿主目录写入数据
[root@localhost ~]#docker run -itd -v /var/www:/data1 --name c1 centos:7 /bin/bash
[root@localhost ~]#docker run -itd -v /var/www:/data2 --name c2 centos:7 /bin/bash
另外开两个终端,分别登陆c1 c2容器,并查看挂载点目录里的文件
在C2容器上创建一个文件,宿主机和C1上也能看到
二、数据卷容器
1、数据卷容器作用
让两个容器实现数据共享。
如果需要在容器之间共享一些数据,最简单的方法就是使用数据卷容器。数据卷容器是一个普通的容器,专门提供数据卷给其他容器挂载使用。php ---->mysql之间想要通讯,通过socket。
2、创建数据卷容器
[root@localhost ~]#docker run -it --name test1 -v /data1 -v /data2 centos:7 /bin/bash #创建并进入容器
[root@40f6b40309af /]# echo "this is test02 file" > /data1/test.txt #容器内创建测试文件1
[root@40f6b40309af /]# echo "this is test01 filells" > /data2/zzz.txt #容器内创建测试文件2
#使用--volumes-from来挂载test2容器中的数据卷到新的容器
[root@localhost ~]#docker run -it --name test2 --volumes-from test1 centos:7 /bin/bash #创建并进入容器
[root@bd1810514f76 /]# cat data1/test.txt #查看测试数据是否同步
this is test02 file
[root@bd1810514f76 /]# cat data2/zzz.txt
this is test01 filells
[root@bd1810514f76 /]#
三、容器互联
使用centos镜像。容器互联是通过容器的名称在容器间建立一条专门的网络通信隧道。简单点说,就是会在源容器和接收容器之间建立一条隧道,接收容器可以看到源容器指定的信息。
1、创建并运行源容器取名web1
[root@localhost ~]#docker run -itd -P --name web1 centos:7 /bin/bash
2、创建并运行接收容器取名web2
使用–link选项指定连接容器以实现容器互联
[root@localhost ~]#docker run -itd -P --name web2 --link web1:web2 centos:7 /bin/bash
进web2容器验证
[root@localhost ~]#docker exec -it web2 bash