Docker容器通信

本文详细介绍了Docker中的三种网络模式(bridge、host、none)以及container网络模式,包括它们的工作原理、创建和连接网络的方法,以及如何实现容器之间的通信,特别是通过自定义网络和DockerDNS进行通信的限制和解决方案。

容器通信

当项目大规模使用 Docker 时,容器通信的问题也就产生了。

要解决容器通信问题,必须先了解很多关于网络的知识。

我们需要了解Docker 的网络知识,以满足更高的网络需求。

1. 默认网络

装 Docker 以后,会默认创建三种网络,可以通过 docker network ls 查看

[root@localhost ~]# docker network ls
NETWORK ID          NAME                DRIVER              SCOPE
f869d1c3534a        bridge              bridge              local
1543d4d4b945        host                host                local
d06a4fca4238        none                null                local
网络模式 简介
bridge 为每一个容器分配、设置 IP 等,并将容器连接到一个 docker0 虚拟网桥,默认为该模式。
host 容器将不会虚拟出自己的网卡,配置自己的 IP 等,而是使用宿主机的 IP 和端口。
none 容器有独立的 Network namespace,但并没有对其进行任何网络设置,如分配 veth pair 和网桥连接,IP 等。
container 新创建的容器不会创建自己的网卡和配置自己的 IP,而是和一个指定的容器共享 IP、端口范围等。

1.1 bridge 网络模式

在该模式中,Docker 守护进程创建了一个虚拟以太网桥 docker0,新建的容器会自动桥接到这个接口,附加在其上的任何网卡之间都能自动转发数据包。

默认情况下,守护进程会创建一对对等虚拟设备接口 veth pair,将其中一个接口设置为容器的 eth0 接口(容器的网卡),另一个接口放置在宿主机的命名空间中,以类似 vethxxx 这样的名字命名,从而将宿主机上的所有容器都连接到这个内部网络上。

veth是linux的一种虚拟网络设备,它有点类似于两张网卡中间用一条网线连着,veth设备总是成对出现,通常用来连接不同网络命名空间(下面开始简称NS),一端连着NS1的内核协议栈,另一端连着NS2的内核协议栈,一端发送的数据会立刻被另一端接收。

在这里插入图片描述

比如我运行一个基于 busybox 镜像构建的容器 bbox01,查看 ip addr

busybox 被称为嵌入式 Linux 的瑞士军刀,整合了很多小的 unix 下的通用功能到一个小的可执行文件中

在这里插入图片描述

然后宿主机通过 ip addr 查看信息如下:

在这里插入图片描述

通过以上的比较可以发现,证实了之前所说的:守护进程会创建一对对等虚拟设备接口 veth pair,将其中一个接口设置为容器的 eth0 接口(容器的网卡),另一个接口放置在宿主机的命名空间中,以类似 vethxxx 这样的名字命名。

同时,守护进程还会从网桥 docker0 的私有地址空间中分配一个 IP 地址和子网给该容器,并设置 docker0 的 IP 地址为容器的默认网关

Docker容器之间可以通过多种方式进行通信。根据媒介,可以使用volume共享通信和网络通信等方式。根据通信范围,可以分为同主机通信和跨主机通信。其中,网络通信方法是本文的主要讨论内容。 Docker的网络驱动模型提供了不同的网络模式,其中最常用的是bridge模式。在bridge模式下,容器会创建独立的网络命名空间,具有独立的网卡和网络栈。这是Docker网络的默认设置。当我们通过docker run命令启动容器时,如果没有指定--net参数,就会默认采用bridge模式。系统会自动创建一个网桥docker0,新创建的容器会通过DHCP获取一个与docker0同网段的IP地址,并连接到docker0网桥,从而实现容器与宿主机的网络互通。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Docker容器间通信方法](https://blog.youkuaiyun.com/THMAIL/article/details/104081435)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [Docker篇之docker容器之间的通信](https://blog.youkuaiyun.com/xu710263124/article/details/115587587)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [Docker容器间网络通信](https://blog.youkuaiyun.com/woshaguayi/article/details/119384333)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值