Docker容器数据管理

1、Docker容器数据的管理方式

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

2、容器数据卷

(1)定义

docker容器数据卷是什么?

  • 将运用与运行的环境打包形成容器运行 ,运行可以伴随着容器,但是我们对数据的要求希望是持久化的
  • 容器之间希望有可能共享数据

Docker容器产生的数据,如果不通过docker commit生成新的镜像,使得数据做为镜像的一部分保存下来,
那么当容器删除后,数据自然也就没有了。
为了能保存数据在docker中我们使用卷。
能干什么
卷就是目录或文件,存在于一个或多个容器中,由docker挂载到容器,但不属于联合文件系统,因此能够绕过Union File System提供一些用于持续存储或共享数据的特性:
卷的设计目的就是数据的持久化,完全独立于容器的生存周期,因此Docker不会在容器删除时删除其挂载的数据卷
特点:
1:数据卷可在容器之间共享或重用数据
2:卷中的更改可以直接生效
3:数据卷中的更改不会包含在镜像的更新中
4:数据卷的生命周期一直持续到没有容器使用它为止

docker容器数据卷作用:

  • 容器的持久化
  • 容器间继承+共享数据

(2)命令添加Docker容器数据卷

命令:
docker run --name 容器名 -i -t -p 主机端口:容器端口 -d -v 主机目录:容器目录:ro 镜像id或镜像名称:tag

说明:
1.-v 指定挂载主机目录到容器目录,默认为rw读写模式,ro表示只读
2.宿主机本地目录的路径必须是使用绝对路径。如果路径不存在,Docker会自动创建相应的路径

(3)案例

centos镜像添加为例,执行:
docker run --name yhw/centos -it -d -v 主机目录:容器目录 镜像id或镜像名称:tag

 说明:1、Docker挂载主机目录Docker访问出现cannot open directory .: Permission denied 
      2、解决办法:在挂载目录后多加一个--privileged=true参数即可

 

 (4)查看数据卷是否挂载成功

docker inspect 容器ID

 (5)命令带权限

docker run --name yhwcentos -it -d -v 主机目录:容器目录:ro 镜像id或镜像名称:tag
 

(6)创建文件测试

  1. 在宿主机的挂载目录创建文件测试数据卷
  2. 在数据卷创建文件测试宿主机的挂载目录

 

3、数据卷容器

(1)定义

概念:命名的容器挂载数据卷,其它容器通过挂载这个(父容器)实现数据共享,挂载数据卷的容器,称之为数据卷容器

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

(2)容器间传递共享(--volumes-from)

命令:docker run -it --name 子容器名 --volumes-from 父容器名镜像id或镜像名称:tag  镜像id

(3)案例:创建一个容器作为数据卷容器

docker run -itd --name web2 -v /data1 -v /data2 -v /data3 centos:7 /bin/bash               
docker exec -it 7089958811d3 bash  #进入数据卷容器
echo "11111" > /data1/123.txt
echo "22222" > /data2/456.txt
echo "33333" > /data3/789.txt
exit
第一步,先启动父容器web1

(4)挂载数据卷容器中的数据卷到新的容器

使用--volumes-from来挂载web2容器中的数据卷到新的容器
 
docker run -itd --volumes-from web2 --name web3 centos:7 /bin/bash
docker exec -it 02c46e912b19 bash   #进入新容器
cat /data1/123.txt
cat /data2/456.txt
cat /data3/789.txt

 第二步,再启动子容器web2,继承父容器web1

第三步,验证数据是共享

 结论:容器之间配置信息的传递,数据卷的生命周期一直持续到没有容器使用为止

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

(1)定义

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

(3)创建容器互联

1.#创建并运行源容器取名web1
docker run -itd -P --name web1 centos:7 /bin/bash
2.#创建并运行接收容器取名web2,使用--1ink选项指定连接容器以实现容器互联
3.docker run -itd -P --name web2 --link web1:jc centos:7 /bin/bash      #--link容器名:连接的别名
4.#进web2容器,ping sb/web1
docker exec -it web2 bash
ping web1/jc

 

 

posted on 2023-08-29 11:48  uestc2007  阅读(41)  评论(0编辑  收藏  举报

导航