【Docker】Docker的数据管理和网络通信

本文详细介绍了Docker的数据管理,包括数据卷和数据卷容器,以及容器间的互联。此外,还深入探讨了Docker镜像的创建,如基于已有镜像、本地模板和Dockerfile创建,并解析了Dockerfile的常用指令、镜像加载原理和容器启动过程。
摘要由CSDN通过智能技术生成


一、Docker 的数据管理

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

1. 数据卷

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

docker pull centos:7

在这里插入图片描述

#宿主机目录/var/ www挂载到容器中的/datal。
docker run -v /var/www:/data1 --name web1 -it centos:7 /bin/bash    #-v选项可町以在容器内创建数据卷
ls
echo "this is web1" > /data1/abc.txt
exit

注意:宿主机本地目录的路径必须是使用绝对路径。如果路径不存在,Docker会自动创建相应的路径

在这里插入图片描述

#返回宿主机运行窗口
cat /var/www/abc.txt

在这里插入图片描述

2. 数据卷容器

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

#创建一个容器作为数据卷容器
docker run --name web2 -v /data1 -v /data2 -it centos:7 /bin/bash

echo "this is web2" > /data1/abc.txt
echo "THIS IS WEB2" > /data2/ABC.txt

在这里插入图片描述

#使用 ―-volumes-from 来挂载 web2 容器中的数据卷到新的容器
docker run -it --volumes-from web2 --name web3 centos:7 /bin/bash

cat /data1/abc.txt
cat /data2/ABC.txt

在这里插入图片描述

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

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

#创建并运行源容器取名web1
docker run -itd -P --name web1 centos:7 /bin/bash	

#创建并运行接收容器取名web2,使用--link选项指定连接容器以实现容器互联
docker run -itd -P --name web2 --link web1:web1 centos:7 /bin/bash   #--link容器名:连接的别名

在这里插入图片描述

#进web2容器,ping web1
docker exec -it web2 bash
ping web1

在这里插入图片描述

三、 Docker 镜像的创建

  创建镜像有三种方法,分别为基于己有镜像创建、基于本地模板创建以及基于Dockerfile创建。

1. 基于己有镜像创建

  首先启动一个镜像,在容器里做修改。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我的宝贝大唐

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值