Docker容器数据管理-数据卷和数据卷容器

导读:本篇文章讲解 Docker容器数据管理-数据卷和数据卷容器,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com


前言

管理 Docker容器中数据主要有两种方式:数据卷(Data Volumes)和数据卷容器(DataVolumes Containers ) 。

一、如何管理docker容器中的数据?

在这里插入图片描述

二、数据卷

1、数据卷原理

将容器内部的配置文件目录,挂载到宿主机指定目录下

  • 1.数据卷默认会一直存在,即使容器被删除
  • 2.宿主机和容器是两个不同的名称空间,如果想进行连接需要用ssh,exec和attch也类似于ssh这种方式登录
  • 3.在企业中ssh这种登陆方式会比较危险,安全漏洞很大,尽量减少ssh这种,杜绝了频繁使用exec
  • 4.因此使用数据卷的方式把容器内部的文件目录挂载到宿主机指定目录下进行修改,当容器里的文件频繁需要修改时不需要登陆进去,直接使用数据卷方式在宿主机指定的目录下进行修改即可。方便又安全

2、数据卷作用

数据卷是一个供容器使用的特殊目录,位于容器中。可将宿主机的目录挂载到数据卷上,对数据卷的修改操作立刻可见,并且更新数据不会影响镜像,从而实现数据在宿主机与容器之间的迁移。数据卷的使用类似于Linux下对目录进行的 mount操作。

3、数据卷实例

实例:将宿主机目录 /var/www 分别挂载到c1 c2容器中的 /data1,/data2

3.1 创建两个容器,指定挂载点,并在宿主目录写入数据

docker run -itd -v /var/www:/data1 --name c1 centos:7 bash
docker run -itd -v /var/www:/data2 --name c2 centos:7 bash

#在宿主机目录写入数据
echo "this is shouzhuji > txt

在这里插入图片描述

3.2 另外开两个终端,分别登陆c1 c2容器,并查看挂载点目录里的文件

在这里插入图片描述

3.3 在C2容器上创建一个文件,宿主机和C1上也能看到

在这里插入图片描述
在这里插入图片描述

三、数据卷容器

1、数据卷容器作用

让两个容器实现数据共享

如果需要在容器之间共享一些数据,最简单的方法就是使用数据卷容器。数据卷容器是一个普通的容器,专门提供数据卷给其他容器挂载使用。

php —->mysql之间想要通讯,通过socket

2、数据卷容器实例

需求:创建数据卷容器

#创建一个容器作为数据卷容器
docker run -it --name test1 -v /data1 -v /data2 centos:7 bash	#创建并进入容器
echo "this is test02 file" > /data1/test.txt		  	#容器内创建测试文件1
echo "THIS IS TEST2 FILE" > /data2/TEST.txt					#容器内创建测试文件2

#使用--volumes-from来挂载test2容器中的数据卷到新的容器
docker run -it --name test2 --volumes-from test1 centos:7 bash	#创建并进入容器
cat data1/test.txt											#查看测试数据是否同步
cat data2/TEST.txt


2.1 创建一个容器作为数据卷容器并创建文件

在这里插入图片描述

2.2 使用–volumes-from来挂载test2容器中的数据卷到新的容器

在这里插入图片描述

四、容器互联(使用centos镜像)

容器互联是通过容器的名称在容器间建立一条专门的网络通信隧道。简单点说,就是会在源容器和接收容器之间建立一条隧道,接收容器可以看到源容器指定的信息。

使用–1ink选项指定连接容器以实现容器互联

[root@yzq tomcat]# docker run -d -P --name tomcat  tomcat:v2  //创建源容器
d160125c8e5373face71b29cb0dff715f6e2cbb5cd1a2f4f5acf374c28d8c09a
[root@yzq tomcat]# docker run -d -P --name tomcat2 --link tomcat:tomcat tomcat:v2  //创建接收容器
3fce1b17ec497ea776995b4bed527dca378d6f9f803b024cf1b4e925b46d84ed
[root@yzq tomcat]# docker exec -it tomcat2 /bin/bash    //进入容器测试
[root@3fce1b17ec49 /]# ping tomcat
PING tomcat (172.17.0.2) 56(84) bytes of data.
64 bytes from tomcat (172.17.0.2): icmp_seq=1 ttl=64 time=0.079 ms
64 bytes from tomcat (172.17.0.2): icmp_seq=2 ttl=64 time=0.101 ms
64 bytes from tomcat (172.17.0.2): icmp_seq=3 ttl=64 time=0.107 ms
^C
--- tomcat ping statistics ---
3 packets transmitted, 3 received, 0% packet loss, time 1999ms
rtt min/avg/max/mdev = 0.079/0.095/0.107/0.016 ms
[root@3fce1b17ec49 /]# 


总结

本文介绍了通过数据卷和数据卷容器对容器内数据进行共享、备份和恢复等操作,通过这些机制,即使容器在运行中出现故障,用户也不必担心数据发生丢失,只需要快速地重新创建容器即可。在生成容器的同时,加上-v选项,指定把当前服务器的目录映射到容器中。

命令 说明
docker run -v 数据卷 创建数据卷
docker run -v 宿主机目录:数据卷 挂载宿主机目录
docker run –volumes-from 数据卷容器 挂载数据卷容器(挂载点路径不变)
docker run –link 源容器名:别名 容器互联
  • 创建Docker镜像有三种方法:基于已有镜像创建,基于本地模板创建,基于Dockerfile文件创建
  • 容器中管理数据有数据卷和数据卷容器两种方法
  • Docker可以使用映射容器端口到宿主机和容器互联机制来实现网络访问

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/76513.html

(0)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!