【Docke笔记】Docker网络模式与容器间通信

2023-10-08 10:20

本文主要是介绍【Docke笔记】Docker网络模式与容器间通信,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本篇主要是Docker网络模式与容器间通信。
上一篇:【Docker基础篇】Docker核心概念与指令

文章目录

  • 一、预备知识点
  • 二、Docker网络模式
    • 1、查看Docker网络模式
    • 2、bridge网络模式
      • - 原理
      • - 实现
      • - 图解
    • 3、host网络模式
      • - 原理
      • - 实现
      • - 图解
    • 4、none网络模式
      • - 原理:
      • - 实现:
    • 5、container 网络模式
      • - 原理:
      • - 实现:
      • - 图解:
  • 三、自定义网络
    • 1、用自定义网络实现容器互连
    • 2、网络的连接、断开与移除
    • 3、DNS

在这里插入图片描述

一、预备知识点

了解Docker网络模式前,先准备点计算机网络。

1、Veth:
Veth是Linux中一种虚拟出来的网络设备,veth设备总是成对出现,所以一般也叫veth-pair。veth模拟了在物理世界里的两块网卡,以及一条网线。通过它可以将两个虚拟的设备连接起来,让他们之间相互通信。

在这里插入图片描述
如:v-a和v-b是一对veth设备,v-a收到的数据会从v-b发出。相反,v-b收到的数据会从v-a发出。Veth就像一根网线。
在这里插入图片描述
Veth设备的特点:

  • veth和其它的网络设备都一样,一端连接的是内核协议栈
  • veth设备是成对出现的,另一端两个设备彼此相连
  • 一个设备收到协议栈的数据发送请求后,会将数据发送到另一个设备上去
    在这里插入图片描述

veth的2头都直接连着网络协议栈,所以创建一个veth对,主机上就会多2个网卡。
在这里插入图片描述
veth的实现和底层理解参考这里。

2、eth0:
ethernet的简写,以太网接口与网卡对应,每个硬件网卡(一个MAC)对应一个以太网接口,其工作完全由网卡相应的驱动程序控制。

如果物理网卡只有一个,而却有eth1,eth2等,则可能存在无线网卡或多个虚拟网卡,虚拟网卡由系统创建或通过应用层程序创建,作用与物理网卡类似。
在这里插入图片描述

3、网卡和网桥
在这里插入图片描述

参考这里。

二、Docker网络模式

1、查看Docker网络模式

docker network ps

安装 Docker 以后,会默认创建三种网络:bridge、host、none
在这里插入图片描述

网络模式特点
bridge为每个容器分配、设置IP等,并将容器连接到一个docker0虚拟网桥,默认为bridge模式
host容器将不会虚拟出自己的网卡,也不会配置自己的IP,而是使用宿主机的IP和端口
none容器有独立的Network namespace ,但并没有对其进行任何网络设置,如分配veth和网桥连接、IP等
container新创建的容器不会创建自己的网卡、配置自己的IP,而是和一个指定的容器共享IP、端口范围等

2、bridge网络模式

- 原理

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

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

- 实现

首先以busybox为镜像创建容器net01(BusyBox 是一个集成了三百多个最常用Linux命令和工具的软件)

docker run -it --name net01 busybox

ip addr查看信息:
在这里插入图片描述
查看宿主机的ip addr信息:
在这里插入图片描述

可以看到:
守护进程创建的一对对等虚拟设备接口 veth pair,将其中一个接口设置为容器的 eth0 接口(容器的网卡),另一个接口放置在宿主机的命名空间中,即图中的veth7353413

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

查看网桥信息
brctl show
#指令安装:
yum install -y bridge-utils

在这里插入图片描述
容器的IP地址和Gateway信息,可以docker inspect在NetworkSettings中查看

docker inspect 容器名 |grep  -i NetworkSettings -A 50|grep -Ei "Gateway|IPAddress

在这里插入图片描述
查看bridge网络模式下的所有容器信息:

docker network inspect bridge

在这里插入图片描述
因bridge是创建容器时默认使用的网络模式,所以docker run时不用加–net bridge指定

- 图解

在这里插入图片描述
步骤总结就是:

  • Docker Daemon 利用 veth pair 技术,在宿主机上创建一对对等虚拟网络接口设备,假设为 veth0 和 veth1。而 veth pair 技术的特性可以保证无论哪一个 veth 接收到网络报文,都会将报文传输给另一方。

  • Docker Daemon 将 veth0 附加到 Docker Daemon 创建的 docker0 网桥上。保证宿主机的网络报文可以发往 veth0;

  • Docker Daemon 将 veth1 添加到 Docker Container 所属的 namespace 下,并被改名为 eth0。如此一来,宿主机的网络报文若发往 veth0,则立即会被 Container 的 eth0 接收,实现宿主机到 Docker Container 网络的联通性;同时,也保证 Docker Container 单独使用 eth0,实现容器网络环境的隔离性。

3、host网络模式

- 原理

host网络模式的容器,直接使用宿主机的 IP 地址与外界进行通信,若宿主机的 eth0 是一个公有 IP,那么容器也拥有这个公有 IP,无需额外进行 NAT 转换,同时容器内服务的端口也可以使用宿主机的端口。

host 网络模式可以让容器共享宿主机网络栈,这样的好处是外部主机与容器直接通信,但是容器的网络缺少隔离性。

- 实现

创建host网络模式的容器net02,注意这时要加–net host指定模式:

docker run -it --name net02 --net host busybox

ip addr查看信息,和宿主机的ip addr信息完全一致

在这里插入图片描述
再查看host网络模式下的所有容器信息,可以看到net02容器

docker network inspect host

在这里插入图片描述

- 图解

在这里插入图片描述

4、none网络模式

- 原理:

none 网络模式是指禁用网络功能,只有 lo 接口。

none 网络模式即不为 Docker Container 创建任何的网络环境,容器内部就只能使用 loopback 网络设备,不会再有其他的网络资源。

lo,即locate,lo其实是一个系统虚拟的环回接口,它的IP地址是127.0.0.1,利用这个接口可以实现系统内部(一个本地进程为另一个本地进程)发送和接收数据。

- 实现:

–net none指定容器网络模式,创建net03容器

docker run -it --name net03 --net none busybox

在这里插入图片描述
docker network inspect none 查看所有 none 网络模式下的容器:
在这里插入图片描述

5、container 网络模式

- 原理:

创建容器时通过参数 --net container:容器名称或ID。Container 网络模式即新创建的容器不会创建自己的网卡,配置自己的 IP,而是和一个指定的容器共享 IP、端口范围等

处于这个模式下的 Docker 容器会共享一个网络栈,这样两个容器之间可以使用 localhost 高效快速通信,两个容器除了网络方面相同之外,其他的如文件系统、进程列表等还是隔离的

- 实现:

基于容器net01创建container网络模式的容器net04

docker run -it --name net04 --net container:net01 busybox

查看net04和net01的addr信息:
在这里插入图片描述
可以看到,容器net04直接使用了net01的网卡信息。此时,stop容器net01,容器net04就只剩下lo接口了:
在这里插入图片描述
接下来重启net01,再重启net04,可以看到网卡信息恢复正常了:
在这里插入图片描述

- 图解:

在这里插入图片描述


三、自定义网络

考虑到安全性问题,实际开发中,我们常使用自定义网络来进行容器间的通信。

从 Docker 1.10 版本开始,docker daemon 实现了一个内嵌的 DNS server,使容器可以直接通过容器名称(run的时候用–name指定)通信。但是使用 Docker DNS 有个限制:只能在 user-defined 网络中使用,即自定义网络,而不是安装Docker后自带的三个网络。

1、用自定义网络实现容器互连

第一步:新建网络,起名test–net

docker network create -d bridge test--net

参数:

  • -d:参数指定 Docker 网络类型,即–driver
  • 更多参数可docker network create --help查看

在这里插入图片描述


第二步:运行一个容器并连接到新建自定义网络 test–net

docker run -it --name net05 --net test--net busybox

docker inspect 查看容器的网络信息,在NetworkSettings中:
在这里插入图片描述


第三步:再创建一个容器,并连接到新建自定义网络 test–net,并ping上一步中创建的容器
在这里插入图片描述
当然,ping容器的Name和IP地址都可以,操作如下图:
在这里插入图片描述

可以看到容器net05和net06成功建立了互连关系!

2、网络的连接、断开与移除

  • 连接网络
docker network connect 网络名称 容器名称 

docker inspect 查看网络信息可以看到多了一个默认的bridge:
在这里插入图片描述

  • 断开网络
docker network disconnect 网络名称 容器名称

断开net05新增的bridge网络,再docker inspect 查看容器网络信息,只剩一个test–net网络了:
在这里插入图片描述

  • 移除网络
docker network rm 网络名称

删除某自定义网络,但当通过该自定义网络创建了容器,则该网络无法删除。

3、DNS

最后,关于DNS,可在宿主机的/etc/docker/daemon.json文件中来增加以下内容来设置全部容器的DNS:

{"dns" : ["114.114.114.114","8.8.8.8"]
}

设置后,启动容器的 DNS 会自动配置为 114.114.114.114 和 8.8.8.8.8。配置完成后,需要重启docker才能生效,重启所有docker直接systemctl restart docker


systemtl系列指令功能强大,了解更多可跳这里here。

这篇关于【Docke笔记】Docker网络模式与容器间通信的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/164601

相关文章

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

poj 3181 网络流,建图。

题意: 农夫约翰为他的牛准备了F种食物和D种饮料。 每头牛都有各自喜欢的食物和饮料,而每种食物和饮料都只能分配给一头牛。 问最多能有多少头牛可以同时得到喜欢的食物和饮料。 解析: 由于要同时得到喜欢的食物和饮料,所以网络流建图的时候要把牛拆点了。 如下建图: s -> 食物 -> 牛1 -> 牛2 -> 饮料 -> t 所以分配一下点: s  =  0, 牛1= 1~

poj 3068 有流量限制的最小费用网络流

题意: m条有向边连接了n个仓库,每条边都有一定费用。 将两种危险品从0运到n-1,除了起点和终点外,危险品不能放在一起,也不能走相同的路径。 求最小的费用是多少。 解析: 抽象出一个源点s一个汇点t,源点与0相连,费用为0,容量为2。 汇点与n - 1相连,费用为0,容量为2。 每条边之间也相连,费用为每条边的费用,容量为1。 建图完毕之后,求一条流量为2的最小费用流就行了

poj 2112 网络流+二分

题意: k台挤奶机,c头牛,每台挤奶机可以挤m头牛。 现在给出每只牛到挤奶机的距离矩阵,求最小化牛的最大路程。 解析: 最大值最小化,最小值最大化,用二分来做。 先求出两点之间的最短距离。 然后二分匹配牛到挤奶机的最大路程,匹配中的判断是在这个最大路程下,是否牛的数量达到c只。 如何求牛的数量呢,用网络流来做。 从源点到牛引一条容量为1的边,然后挤奶机到汇点引一条容量为m的边

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP