【Docker】数据管理与Dockerfile

这篇博客详细介绍了Docker的数据管理,包括数据卷和数据卷容器的使用,以及端口映射和容器互联。此外,还深入讨论了Docker镜像的创建过程,如基于现有镜像、本地模板和Dockerfile创建,并解析了Docker镜像的分层结构和联合文件系统。同时,文中还解释了Dockerfile的操作指令和容器间的网络报错解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

Docker 的数据管理

1.数据卷

2.数据卷容器

端口映射

容器互联(使用centos镜像)

Docker 镜像的创建

1.基于现有镜像创建

2.基于本地模板创建

3.基于Dockerfile 创建

联合文件系统(UnionFS)

镜像加载原理

为什么Docker里的centos的大小才200M?

Dockerfile

Docker 镜像结构的分层

Dockerfile 操作常用的指令:

Dockerfile 案例

如果有网络报错提示

解决方法:


Docker 的数据管理

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

1.数据卷

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

docker pull centos:7

#宿主机目录/var/www 挂载到容器中的/data1。
注意:宿主机本地目录的路径必须是使用绝对路径。如果路径不存在,Docker会自动创建相应的路径。

docker run -v /var/www:/data1 --name web1 -it centos:7 /bin/bash            #-v 选项可以在容器内创建数据卷
ls
echo "ggl like ycx!" > /data1/ggl.txt
exit

 #返回宿主机进行查看

cat  /var/www/qhw.txt

2.数据卷容器

如果需要在容器之间共享一些数据,最简单的方法就是使用

数据卷容器。数据卷容器是一个普通的容器,专门提供数据卷给其他容器挂载使用。
#创建一个容器作为数据卷容器

docker run --name web2 -v /data1 -v /data2 -it centos:7 /bin/bash
echo "this is my world!" > /data1/myworld.txt
echo "this is my city!" > /data2/mylove.txt
docker run --name web2 -v /data1 -v /data2 -it centos:7 /bin/bash
cd /data1/
vi myworld.txt
cd /data2/
vi mylove.txt
exit

#使用 --volumes-from 来挂载 web2 容器中的数据卷到新的容器

docker run -it --volumes-from web2 --name web3 centos:7 /bin/bash
cat /data1/myworld.txt
cat /data2/mylove.txt

端口映射

在启动容器的时候,如果不指定对应的端口,在容器外是无法通过网络来访问容器内的服务。端口映射机制将容器内的服务提供给外部网络访问,实质上就是将宿主机的端口映射到容器中,使得外部网络访问宿主机的端口便可访问容器内的服务。

docker run -d --name test1 -P nginx                    #随机映射端口(从32768开始)

docker ps  -a

在另一台主机上输入地址和相应端口

docker run -d --name test2 -p 43000:80 nginx        #指定映射端口

 docker ps -a

浏览器访问:http://192.168.110.100:43000    、http://192.168.110.100:49170

容器互联(使用centos镜像)

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

docker run -itd -P --name z1 centos:7 /bin/bash

创建并运行接收容器取名中z2,使用--link选项指定连接容器以实现容器互联

docker run -itd -P --name z2 --link z1:z1 centos:7 /bin/bash            #--link 容器名:连接的别名

进z2 容器, ping z1

docker exec -it z2 bash
ping z1
ping z1
PING z1 (172.17.0.4) 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值