Docker高级篇之Docker网络

news2025/1/11 15:05:56

文章目录

    • 1. Docker Network简介
    • 2. Docker 网络模式
    • 3. Docker 网络模式之bridge
    • 4. Docker 网络模式之host
    • 5. Docker 网络模式之none
    • 6. Docker 网络模式之container
    • 7. Docker 网络模式之自定义网络模式

1. Docker Network简介

从Docker的架构和运作流程来看,Docker是一个C/S模式的架构,后端是一个松耦合架构,众多模块各司其职。Docker运作的基本流程是:

  1. 用户是使用Docker Client与Docker Daemon建立通信,并发送请求给后者
  2. Docker Daemon作为Docker架构的主体部分,首先提供Docker Server的功能使其可以接受Docker Client的请求
  3. Docker Engine执行Docker内部的一系列工作,每一项工作都是以一个job的形式存在
  4. Job的运行流程中,当需要容器镜像的时候,则从Docker Registry中下载镜像,并通过镜像管理驱动Graph Driver将下载镜像以Graph的形式存储
  5. 当需要为Docker创建网络环境时,通过网路管理器驱动NetWork driver创建并配置Docker容器网络环境
  6. 当需要限制Docker容器运行资源或执行用户命令的时候,则通过Execdriver来完成
  7. Libcontainer是一项独立的容器管理包,NetWork driver以及Exec driver都是通过Libcontainer来实现具体对容器进行的操作

我们可以使用下面的命令来查看docker的所有网络情况:

docker network ls

在这里插入图片描述

bridge host 和 none是Docker 默认创建的

使用下面命令可以创建一个docker network:

docker network create test_network

在这里插入图片描述

使用下面命令可以删除一个docker网络:

docker network rm test_network

使用下面命令可以查看某个网络的详细信息:

docker network inspect bridge

在这里插入图片描述

Docker网络主要是实现两个功能:

  • 容器间的互联和同学以及端口映射
  • 容器IP变动时可以通过服务名直接网络通信而不受到影响

2. Docker 网络模式

签名说到Docker会默认给我们创建bridge、host和none三个网络模式。Docker常见的网络模式如下所示:

网络模式简介使用方式
bridge为每一个容器分配、设置IP,并将容器链接到一个docker0,虚拟网桥,docker默认为该模式–network bridge指定,默认是docker 0
host容器将不会虚拟出自己的网卡,配置自己的IP地址,而是使用宿主机的IP和端口使用–network host指定
none容器有独立的Network namespace,但并没有对其进行任何网络设置,如分配veth pair和网桥连接,IP等使用–network none指定
container新建立的容器不会创建自己的网卡和配置自己的IP,而是和一个指定的容器共享IP、端口范围等使用–network container:Name或者容器ID指定
  • docker netwrok底层ip和容器映射关系变化

我们启动两个ubuntu容器并进入ubuntu的容器内:

docker run -it --name u1 ubuntu bash
docker run -it --name u2 ubuntu bash

在这里插入图片描述
我们首先看一下u1的情况:

docker inspect u1

在这里插入图片描述
我们再看看u2:

在这里插入图片描述
可以发现u1和u2的网络ip都不一样。现在将u2删除,然后再启动一个u3,再次查看网络情况:

在这里插入图片描述
我们可以发现u3复用来u2的ip地址,这里就出现一个关键问题,如果我们在bridege情况下将容器ip写死的话,如果某个容器宕机了,它的ip地址可能被其它容器复用,这样就导致了访问u2的ip地址,可能访问到的是u3的内容,所以在访问容器服务时,不能通过固定的ip地址访问。所以我们要规划好我们的docker network

3. Docker 网络模式之bridge

Docker服务默认会创建一个docker0网桥(其上有一个docker0内部接口),该桥接网络的名称为docker 0,它在内核层连通了其他的物理或虚拟网卡,这就是将容器和本地主机都放在同一个物理网络,Docker默认指定了docker0接口的IP地址和子网掩码,让主机和容器之间可以通过网桥相互通信。

在组网方面,网桥网络是一种链路层设备,用于转发网段之间的流量。网桥可以是在主机内核中运行的硬件设备或软件设备。在Docker方面,网桥网络使用软件网桥,允许连接到同一网桥网络的容器进行通信,同时提供与未连接到该网桥网络的容器的隔离。Docker Bridge驱动程序自动在主机中安装规则,使不同网桥网络上的容器无法直接通信。网桥网络适用于运行在同一个Docker守护进程主机上的容器。对于运行在不同Docker守护进程主机上的容器之间的通信,可以在操作系统级别管理路由,也可以使用覆盖网络。启动Docker时,将自动创建默认网桥网络(也称为网桥),除非另有指定,否则新启动的容器将连接到该网络。还可以创建用户定义的自定义网桥网络。用户定义的网桥网络优于默认的网桥网络。

Docker使用Linux桥接,在宿主机虚拟一个Docker容器网桥,Docker启动一个容器时会根据Docker网桥的网段分配给容器一个IP地址,称为Container-IP,同时Docker网桥是每个容器的默认网关。因为在同一个宿主机内的容器都接入同一个网桥,这样容器之间就能通过容器的Container-IP进行通信了。在执行docker run命令时,没有指定network的话默认使用的网桥模式就是bridge,使用的就是docker0。在宿主机上使用ifconfig,就可以看到docker0和自己create的network eth0、eth1、eth2,代表网卡1、网卡2…,lo代表127.0.0.1,即localhost,inet addr用来表示网卡的IP地址。

网桥docker0创建一对对虚拟设备接口叫做veth,另一个叫eth0,成对匹配:

  • 整个宿主机的网桥模式都是docker0,类似交换机有一个接口,每个接口叫做veth,在本地主机和容器内分别创建一个虚拟接口,并让他们彼此联通(这样一对接口叫做veth pair)
  • 每个容器实例内部也有一张网卡,每个接口就走eth0
  • docker0上面的每个veth匹配某个容器实例内部的eth0,两两配对,一一匹配

所以,将宿主机上的所有容器都链接到这个内部网络上,两个容器在同一个网络下,就从这个网关下各自拿到分配的ip,此时两个容器的网络是互通的。

在这里插入图片描述

4. Docker 网络模式之host

host模式是直接使用宿主机的ip地址与外界进行通信,不需要额外进行NAT转换。

NAT(Network Address Translation)是一种网络技术,用于在本地网络中使用私有地址,在连接互联网时转而使用全局IP地址。NAT技术主要解决了IPv4地址短缺的问题,通过将一个外部IP地址和端口映射到更大的内部IP地址集来实现IP地址的转换。NAT的实现方式包括静态转换、动态转换和端口多路复用(PAT)。

在host模式下,容器将不会获取一个独立的Network Namespace,而是和宿主机共用一个Network Namespace,容器将不会虚拟出自己的网卡而是使用宿主机的IP和端口。

在这里插入图片描述
我们举一个简单的例子:

docker run -d -p 8081:8080 --network host --name tomcat81 64fbf6b1021d

在这里插入图片描述

我们可以发现在host模式下,端口是空的,这是因为此时容器和主机是共用ip和端口的,所以host模式下端口会失效,端口会以主机端口号为主,重复时则递增

docker inspect tomcat81

在这里插入图片描述

由于和宿主机共用,所以很多配置都是空的,我们进入容器内部看网络配置,可以发现内容就是宿主机的网络配置情况

现在的问题时,因为-p端口失效,如何访问启动好的tomcat呢?(会使用tomcat默认的端口)

在这里插入图片描述

5. Docker 网络模式之none

在这种模式下,docker容器会禁用网络功能,只有lo标识(就是127.0.0.1表示本地回环)。在none模式下,并不为docker容器进行任何网络配置,也就是说,这个Docker容器没有网卡、IP、路由等信息,只有一个lo。需要我们自己为Docker容器添加网卡、配置IP等。

6. Docker 网络模式之container

新建的容器和已经存在的容器共享一个网络ip配置,而是不和宿主机共享。新创建的容器不会创建自己的网卡,配置自己的IP,而是和指定的容器共享IP、端口范围等。同样,两个容器除了网络方面,其他的文件系统、进程列表都是隔离的。

在这里插入图片描述
这里我们使用Alpine操作系统(Alpine时一个面向安全的Linux发行版)来演示:

docker run -it --name alpine1 alpine /bin/sh
docker run -it --network container:alpine1 --name alpine2 alpine /bin/sh

在这里插入图片描述
我们首先查看alpine1的网络情况:

在这里插入图片描述

再查看alpine2的网络情况:

在这里插入图片描述
可以看到alpine2的网卡情况和alpine1完全一致,所以alpine2确实复用了alpine1的网络(alpine1如果关闭了alpine2就会失去访问网络的功能)。

7. Docker 网络模式之自定义网络模式

前面说到Docker默认使用bridge模式,所有的容器都可以互通,如果我们现在的需求时某些业务相关的容器可以互通,而其它容器不能和这些容器通信,这时就需要使用到自定义的网络模式。

下面结合案例理解一下如何使用这种网络模式:

新建立两个tomcat容器:

docker run -d -p 8081:8080  --name tomcat81 64fbf6b1021d
docker run -d -p 8082:8080  --name tomcat82 64fbf6b1021d

在这里插入图片描述

此时默认使用bridge模式

现在我们分别进入两个容器内部:
在这里插入图片描述
然后我们看看根据ip地址是不是两个tomcat容器可以ping通。

tomcat81的ip地址:172.17.0.2
tomcat82的ip地址:172.17.0.3

在这里插入图片描述

可以发现时可以互相ping通的,但是如果现在安装服务名(tomcat81和tomcat82)就ping不通了

现在我们来使用我们的自定义网络:

首先新建立一个网络:

docker network create jackiechai_network

在这里插入图片描述
将tomcat容器加入到这个网络中:

docker run -d -p 8081:8080 --network jackiechai_network  --name tomcat81 64fbf6b1021d
docker run -d -p 8082:8080 --network jackiechai_network  --name tomcat82 64fbf6b1021d

在这里插入图片描述

现在再两个容器内部就可以安装ip或者具体的服务名来ping通了

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1805742.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

normalizing flows vs 直方图规定化

normalizing flows名字的由来 The base density P ( z ) P(z) P(z) is usually defined as a multivariate standard normal (i.e., with mean zero and identity covariance). Hence, the effect of each subsequent inverse layer is to gradually move or “flow” the da…

【报文数据流中的反压处理】

报文数据流中的反压处理 1 带存储体的反压1.1 原理图1.2 Demo 尤其是在NP芯片中,经常涉及到报文的数据流处理;为了防止数据丢失,和各模块的流水处理;因此需要到反压机制; 反压机制目前接触到的有两种:一是基…

【Python入门与进阶】Anaconda环境配置

目录 1.Conda换源 2.pip换源 3.环境管理 4.可视化界面完成上述操作 1.Conda换源 1.1.打开Anaconda Powershell Prompt 1.2.在界面中输入以下命名(加入清华源并设置搜索优先级): conda config --add channels https://mirrors.ustc.edu.…

android集成百度文心一言实现对话功能,实战项目讲解,人人都能拥有一款ai应用

大家好,今天给大家讲解下如何实现一个基于百度文心一言的app功能,app内部同时集成了讯飞的语音识别。本文适用于有android基础的小伙伴阅读,文章末尾放上本项目用到的全部实例代码,在使用前请务必看完本文章。 先来给大家看看效果…

鲜为人知的英伟达创始人:早早退出,身价不如黄仁勋零头

内容提要 普里姆因为婚姻纠纷等个人生活的干扰无法专注在工作上,在成立公司的10年后,也就是2003年宣布退休离开英伟达,并在2006年出售剩余的所有英伟达股份,过上不与外界联系、离群索居的生活,在家中鼓捣着如何“拯救…

【深度学习】深度学习之巅:在 CentOS 7 上打造完美Python 3.10 与 PyTorch 2.3.0 环境

【深度学习】深度学习之巅:在 CentOS 7 上打造完美Python 3.10 与 PyTorch 2.3.0 环境 大家好 我是寸铁👊 总结了一篇【深度学习】深度学习之巅:在 CentOS 7 上打造完美Python 3.10 与 PyTorch 2.3.0 环境✨ 喜欢的小伙伴可以点点关注 &#…

【MySQL】(基础篇三) —— 创建数据库和表

管理数据库和表 管理数据库 创建数据库 在MySQL中,创建数据库的SQL命令相对简单,基本语法如下: CREATE DATABASE 数据库名;如果你想避免在尝试创建已经存在的数据库时出现错误,可以添加 IF NOT EXISTS 子句,这样如…

transformer - 注意力机制

Transformer 的注意力机制 Transformer 是一种用于自然语言处理任务的模型架构,依赖于注意力机制来实现高效的序列建模。注意力机制允许模型在处理一个位置的表示时,考虑输入序列中所有其他位置的信息,而不仅仅是前面的几个位置。这种机制能…

学会python——九九乘法表+斐波那契数列(python实例一)

目录 1、认识Python 2、环境与工具 2.1 python环境 2.2 pycharm编译 2、九九乘法表 2.1 代码构思 2.2 代码示例 2.3 运行结果 3、斐波那契数列 3.1 代码构思 3.2 代码示例 3.3 运行结果 1、认识Python Python 是一个高层次的结合了解释性、编译性、互动性和面向对…

Mac清洁神器CleanMyMac2024一键轻松解决电脑垃圾问题

【CleanMyMac】苹果mac电脑垃圾清理软件 大家好!今天我要给大家种草一个超级好用的苹果mac电脑垃圾清理软件,那就是 CleanMyMac。相信很多人都遇到过电脑运行速度变慢、存储空间不足的问题,而这款软件就是解决这些问题的救星!让我…

UML交互图-协作图

概述 协作图和序列图都表示出了对象间的交互作用,但是它们侧重点不同。序列图清楚地表示了交互作用中的时间顺序,但没有明确表示对象间的关系。协作图则清楚地表示了对象间的关系,但时间顺序必须从顺序号获得。序列图常常用于表示方案&#…

物理机宕机后,虚拟机出现(无响应),虚拟机无法开机

物理机宕机后,虚拟机出现(无响应),虚拟机无法开机 解决方案;看存储池中,文件是否还存在;如果存在,新建虚拟机,加载存储池中的磁盘,重启虚拟机就可以了 重新创…

matlab---app

一 基础 标签和信号灯没有回调函数 clc,clear,close all %清理命令区、工作区,关闭显示图形 warning off %消除警告 feature jit off %加速代码运行 ysw{i}i %循环赋值 celldisp(ysw) %显示元胞数组ysw.y1{1}[1,2] …

【机器学习300问】108、什么是多项式回归模型?

一、多项式回归是什么 (1)举例说明 假设你经营着一家农场,想要根据土地面积来预测作物的产量。如果你只用线性模型(即),你可能会发现它并不足以描述实际的产量情况,因为实际产量可能会随着土地…

美国演员工会SAG-AFTRA 要求人工智能在广告中使用演员声音需征得同意并付费

SAG-AFTRA 的新豁免允许在人工智能生成的广告中使用演员的声音,但需要同意、补偿和安全措施 美国演员工会(SAG-AFTRA)推出了一项新的豁免,以保护会员免受未经授权的人工智能在广告中使用其声音的影响。动态人工智能音频广告豁免定…

添加Microsoft.VisualStudio.TestTools.UnitTesting命名空间

创建“单元测试项目”,则自动添加 Microsoft.VisualStudio.TestTools.UnitTesting 命名空间

《Brave New Words 》2.1 学生为什么要写作

Part II: Giving Voice to the Social Sciences 第二部分:为社会科学发声 Art is a collaboration between God and the artist, and the less the artist does the better. —Andr Gide 艺术是上帝与艺术家的合作,艺术家做得越少越好。 —安德烈纪德 A …

Docker 常用命令以及镜像选择

目录 1.Docker基本组成 2.镜像选择 2.1、镜像推荐选择方案 2.2版本选择 3.Docker 命令 3.1镜像管理 拉取镜像: 列出镜像: 删除镜像: 构建镜像: 3.2容器管理 运行容器 列出运行中的容器和所有容器 停止容器 启动重启…

微服务开发与实战Day04

一、网关路由 网关&#xff1a;就是网络的关口&#xff0c;负责请求的路由、转发、身份校验。 在SpringCloud中网关的实现包括两种&#xff1a; 1. 快速入门 Spring Cloud Gateway 步骤&#xff1a; ①新建hm-gateway模块 ②引入依赖pom.xml(hm-gateway) <?xml version…

(2024,自监督 ViT,全监督 ViT,损失可视化,MAE,RC-MAE,自蒸馏,EMA)可视化自监督 ViT 的损失景观

Visualizing the loss landscape of Self-supervised Vision Transformer 公和众和号&#xff1a;EDPJ&#xff08;进 Q 交流群&#xff1a;922230617 或加 VX&#xff1a;CV_EDPJ 进 V 交流群&#xff09; 目录 0 摘要 2 基础&#xff1a;MAE 和 RC-MAE 3 损失景观 3.1 分…