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)创建文件测试
在宿主机的挂载目录创建文件测试数据卷
在数据卷创建文件测试宿主机的挂载目录
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
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
· 百万级群聊的设计实践
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性