Docker6种网络配置详解,网络模式应该这么选

news2025/1/17 14:05:25

文章目录

      • 一、Bridge网络模式
      • 二、Host网络模式
      • 三、Overlay网络模式
      • 四、None网络模式
      • 五、Macvlan网络模式
      • 六、Ipvlan网络模式
      • 七、网络模式选择

在Docker中,网络配置是一个重要的主题,因为容器需要与其他容器或外部网络进行通信。Docker提供了多种网络模式和配置选项,以便在不同的场景下满足用户的需求。

本文介绍这些网络模式的区别以及配置,相信看完以后你能够掌握Docker网络的配置以及适应不同的场景做出不同的选择。

一、Bridge网络模式

Docker Bridge网络模式是Docker默认的网络模式,它将容器连接到Docker宿主机的虚拟网络中,并为每个容器分配一个IP地址。容器之间可以通过IP地址直接通信,也可以通过容器名称进行通信。

在Bridge网络模式下,Docker会为每个容器创建一个虚拟网桥,容器之间的通信都是通过这个虚拟网桥进行的。Docker宿主机上的所有容器都连接到这个虚拟网桥上,而Docker宿主机本身也是通过一个特殊的容器(名为docker0)连接到这个虚拟网桥上的。

当Docker创建容器时,它会自动为容器分配一个IP地址,并将该地址添加到虚拟网桥的配置中。这样,在容器之间通信时,就可以使用这个IP地址进行通信了。

需要注意的是,Bridge网络模式下的容器只能和同一台主机上的容器通信,无法和其他主机上的容器通信。如果需要实现跨主机通信,可以使用Docker的Overlay网络模式。

使用以下命令带--network bridge选项可以指定启用bridge模式,因为这个模式是默认模式,所以即使完全不指定也是默认使用此模式。

docker run -itd --name mycontainer --network bridge nginx

我本地已经启动了2个容器,是一个springboot应用,通过docker命令可以查看到容器的id

[root@node1 ~]# docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                    NAMES
2d1fd1adc1c7        demo:latest         "java -jar demo-0...."   3 seconds ago       Up 2 seconds        0.0.0.0:8081->8080/tcp   optimistic_mirzakhani
b8a144de27a9        demo:latest         "java -jar demo-0...."   4 hours ago         Up 4 hours          0.0.0.0:8080->8080/tcp   unruffled_mccarthy

使用docker exec命令可以进入容器内部查看IP地址和测试容器与其他容器以及宿主机之间的连通性。

[root@node1 ~]# docker exec -it b8a144de27a9 sh
[root@node1 ~]# docker exec -it 2d1fd1adc1c7 sh

可以看到分别为两个容器分配了IP地址:172.17.0.2和172.17.0.3。

他们之间可以相互ping通,且ping宿主机172.17.0.1网络也是相通的。

通过查看主机的网络,也可以发现有一个docker0的网桥,且IP地址设置为了172.17.0.1。

宿主机也可以访问容器中暴露出来的服务,例如如下访问8080端口暴露的web服务。

二、Host网络模式

在Host网络模式下,容器将直接使用宿主机的网络接口,这样容器就可以像宿主机一样,使用主机的IP地址和端口。因此,这种模式下的容器与主机之间没有网络隔离,但它们与其他容器之间则是隔离的。

与其他Docker网络模式相比,Host网络模式的主要特点包括:

  1. 简单易用:不需要对容器进行网络配置,与宿主机直接共享网络。
  2. 性能高:因为容器与宿主机共享网络,容器之间的通信无需经过网络层,可以获得更高的网络性能。
  3. 安全性较低:容器与宿主机共享网络,容器之间的网络隔离会降低,容器中的应用程序可以直接访问宿主机上的网络接口。

Host网络模式适用于一些特定场景,例如需要访问宿主机上的网络接口、需要最大化网络性能、需要简单易用的网络设置等。

可以通过在运行容器时指定–network=host选项来启动,类似上面Bridge网络模式的验证流程,我们再次创建两个容器。

[root@node1 ~]# docker run -d -p 8080:8080 demo:latest --network host
683e6d67f93ec2546b1627fa68c0902da749daaaeea4be344b9f0320f183fe69
[root@node1 ~]# docker run -d -p 8081:8080 demo:latest --network host
081bd021af82e63094df42fee80f0a58f7fe0bcc36e19f28b18b6b9619863e45

同样进入这两个容器进行连通性验证,发现都是能够正常联通的。且直接从容器中可以访问百度网络,证明与宿主机共享了网络。

三、Overlay网络模式

Overlay网络模式用于连接跨主机的容器。在这种模式下,Docker会创建一个虚拟网络,所有连接到这个虚拟网络的容器都可以相互通信,无论这些容器运行在哪个主机上。Overlay网络模式需要使用Docker Swarm集群管理工具来管理多个Docker主机之间的通信。

这里我启动两个虚拟机,分别在两个虚拟机上各创建1个容器。在使用Overlay网络模式前,需要先创建一个Overlay网络:

docker network create --driver overlay mynetwork

创建一个使用Overlay网络模式的容器:

docker run -itd --name demo --network mynetwork demo:latest

在不同主机上启动多个容器,并连接到同一个Overlay网络:

docker run -itd --name demo1 --network mynetwork demo:latest

在容器内部,使用ping命令测试容器之间是否可以相互通信:

docker exec -it demo ping demo1

发现是可以正常通信的。

四、None网络模式

在None网络模式下,容器不会拥有任何网络接口,也没有IP地址,因此无法与外部网络通信。这种模式通常用于特殊场景,例如需要禁用网络功能的容器。

创建一个使用Host网络模式的容器:

docker run -itd -p 8080:8080 --name demo --network none demo:latest

进入容器内部,可以看到只有一个lo回环网络,没有分配任何IP地址。

五、Macvlan网络模式

Macvlan是一种容器网络模式,它允许Docker容器直接连接到主机的物理网络接口。这使得容器能够直接获得一个IP地址,并且在网络上可以像主机一样运行。Macvlan网络模式的优点是容器的网络性能非常好,而且可以实现容器与主机在同一局域网内相互通信。

在使用Macvlan网络模式时,需要指定一个父网卡(parent interface),也就是一个物理网卡,容器将使用该网卡进行通信。容器可以使用静态IP地址或从DHCP服务器获取IP地址。与其他网络模式相比,Macvlan网络模式的缺点是较为复杂,配置也相对困难。

以下是在Docker中配置和使用Macvlan网络模式的步骤:

  1. 首先,需要创建一个Macvlan网络。可以使用以下命令来创建:

    docker network create -d macvlan \
      --subnet=<subnet> \
      --gateway=<gateway> \
      -o parent=<physical_interface> \
      <network_name>
    

    其中,<subnet>是一个可用于Macvlan网络的子网地址,例如192.168.1.0/24<gateway>是Macvlan网络的网关地址,例如192.168.1.1<physical_interface>是宿主机上用于连接到物理网络的接口名称,例如eth0enp0s3<network_name>是Macvlan网络的名称。

  2. 接下来,需要在Docker容器中使用这个Macvlan网络。可以使用以下命令来运行容器:

    docker run -itd \
      --name=<container_name> \
      --network=<network_name> \
      --ip=<ip_address> \
      <image_name>
    

    其中,<container_name>是容器的名称;<network_name>是上一步中创建的Macvlan网络的名称;<ip_address>是要分配给容器的IP地址,必须是Macvlan网络中的可用地址;<image_name>是要运行的Docker镜像名称。

  3. 容器现在应该已经成功连接到了宿主机上的物理网络,可以使用分配给容器的IP地址来访问容器中运行的服务。

需要注意的是,Macvlan网络模式需要宿主机的网卡支持802.1q VLAN标记,且容器不能与宿主机共享网络命名空间。

六、Ipvlan网络模式

Ipvlan网络模式是另一种容器网络模式,它允许Docker容器使用主机的IP地址来访问网络。不同于Macvlan模式,Ipvlan模式中的容器不需要使用主机的物理网卡,而是通过虚拟的MAC地址来访问网络。Ipvlan模式的优点是配置简单,而且性能也不错。

Ipvlan网络模式支持两种模式:L2模式和L3模式。L2模式使用与Macvlan模式相似的技术,允许容器与主机在同一子网内。L3模式则允许容器与主机在不同的子网内,需要通过路由器进行通信。

要在Docker中配置Ipvlan网络模式,需要以下步骤:

  1. 创建Ipvlan网络

首先,使用以下命令创建一个新的Ipvlan网络:

luaCopy codedocker network create -d ipvlan \
  --subnet=192.168.1.0/24 \
  --gateway=192.168.1.1 \
  -o parent=en0 \
  ipvlan-network

其中:

  • -d ipvlan 指定网络驱动程序为Ipvlan
  • --subnet 指定网络子网
  • --gateway 指定网络网关
  • -o parent 指定网络接口,这里是Mac上的en0
  • ipvlan-network 是网络的名称
  1. 启动容器

现在可以启动一个新的容器,并将其连接到Ipvlan网络:

cssCopy codedocker run --name=my-container \
  --network=ipvlan-network \
  --ip=192.168.1.100 \
  -d \
  nginx

其中:

  • --name 指定容器的名称
  • --network 指定容器连接的网络
  • --ip 指定容器的IP地址
  • -d 指定容器在后台运行
  • nginx 是要运行的容器镜像名称

七、网络模式选择

基于以上介绍做一下Docker网络模式适用场景的总结:

  1. bridge(默认):这种模式适合在单台主机上运行多个容器的场景,且多个容器之间需要互相访问。
  2. host:容器和主机共享网络命名空间和网络接口。这种模式可以实现最大的网络性能和最小的网络延迟,适合需要高网络性能的场景。
  3. none:容器没有网络连接。这种模式适用于特殊的情况,如仅用于生成数据卷的容器。
  4. overlay:在 Docker Swarm 模式下使用的网络模式,允许容器在不同主机上的 Docker 引擎中通信。这种模式适合分布式应用程序的场景。
  5. macvlan:将容器连接到物理网络,每个容器分配一个 MAC 地址。这种模式适合需要容器使用主机网络拥有独立 IP 地址的场景,如在企业内部网络中运行容器,暴露相关的服务供内部人员使用。
  6. ipvlan:类似于 macvlan,但容器共享物理接口,可以更有效地使用网络带宽。这种模式适用于需要在容器之间共享网络命名空间的场景。

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

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

相关文章

GPT-4 和ChatGPT API的定价分析

OpenAI发布了他们的ChatGPT新机器学习模型GPT-4。GPT-4是GPT-3的一大进步&#xff0c;GPT-3是当前ChatGPT免费版本(GPT 3.5 Turbo)所运行的模型的基础&#xff0c;今天我们也来凑个热点&#xff0c;研究一下它们的定价 GPT-4新的功能 GPT-4可以在对话中使用图像&#xff0c;并…

2023年美赛春季赛 赛题浅析

由于今年各种各样的原因&#xff0c;导致美赛头一次&#xff0c;据说也将是最后一次&#xff0c;临时调整&#xff0c;加设春季赛。这对于急需建模奖项的大家来说是一个很好的机会。无论怎样的原因&#xff0c;今年美赛我们可能有所遗憾。但&#xff0c;春季赛也许就是弥补遗憾…

在不丢失数据的情况下解锁锁定的 Android 手机的 4 种方法

尽管您可以使用指纹解锁手机&#xff0c;但大多数智能手机都需要 PIN 码、图案或字母数字代码作为主密码。如果您有一段时间没有输入手机密码&#xff0c;很容易忘记。正是由于这个原因&#xff0c;即使您打开了指纹解锁&#xff0c;大多数智能手机也会让您每天至少输入一次 PI…

Linux之磁盘分区、挂载

文章目录一、Linux分区●原理介绍●硬盘说明查看所有设备挂载情况挂载的经典案例二、磁盘情况查询基本语法应用实例磁盘情况-工作实用指令一、Linux分区 ●原理介绍 Linux来说无论有几个分区&#xff0c;分给哪一目录使用&#xff0c;它归根结底就只有一个根目录&#xff0c;…

【软考五】数据库(做题)

该文章不适合学习数据库&#xff0c;适合考证&#xff0c;遇到实际问题的&#xff0c;不要在这儿浪费时间。切记切记 软考之数据库一、概念数据模型&#xff08;下午题常考&#xff09;二、结构数据模型关系模型1、关系模型中基本术语2、关系模型中的关系完整性约束3、关系代数…

SQL Server 数据查询

文章目录前言首先在SQL Server 2008 中新建一个数据库chaxun.在库中建三个表,结构如下表所示,并且录入数据.1.2.(1)在KC表中查询学分低于三分的课程信息&#xff0c;并按课程号升序排列(2)在XS_KC表中按学号分组汇总学生的平均分&#xff0c;并按平均分的降序排列(3)在XS_KC表中…

「文心一言」内测详细使用体验

★观前提示&#xff1a;以下内容仅为内测测试内容&#xff0c;不代表未来正式版如何&#xff0c;或许你认为它与chatgpt仍有不小的差距&#xff0c;或许你认为它目前做的已经不错了&#xff0c;都可以&#xff0c;但是咱们测试体验&#xff0c;只讲述体验&#xff0c;本篇文章不…

【数字图像处理】直方图均衡化

文章目录1. 算法原理2. 算法缺陷及改进2.1 缺陷2.2 改进3. 实现3.1 调包侠版本3.2 自由发挥版本1. 算法原理 直方图均衡化是一种常见的图像增强方法&#xff0c;可以增强图像的对比度。其数学原理如下&#xff1a; 首先&#xff0c;我们需要了解直方图的概念。直方图是对图像…

Bezier Curve 贝塞尔曲线 - 在Unity中实现路径编辑

文章目录简介一阶贝塞尔曲线二阶贝塞尔曲线三阶贝塞尔曲线图形理解 Bezier Curve一阶贝塞尔曲线二阶贝塞尔曲线三阶贝塞尔曲线应用Bezier CurveSimpleBezierCurvePathSimpleBezierCurvePathAlonger简介 贝塞尔曲线&#xff08;Bezier Curve&#xff09;&#xff0c;又称贝兹曲…

人工智能概述

一、人工智能发展必备三要素 算法 数据 算力 CPU、GPU、TPU 计算力之CPU、GPU对比&#xff1a; CPU主要适合I\O密集型任务GPU主要适合计算密集型任务 什么样的程序适合在GPU上运行&#xff1f; 计算密集型的程序 所谓计算密集型(Compute-intensive)的程序&#xff0c;就是…

【K8S系列】深入解析无状态服务

目录 序言 1. 无服务介绍 1.1 优点 1.2 使用场景 1.3 资源类型 1.4 总结 2 使用介绍 2.1 Deployment 使用场景&#xff1a; 2.2 ReplicaSet 使用场景 2.3 pod Pod 资源定义示例 2.4 service 创建一个Deployment&#xff1a; 创建一个Service&#xff1a; 总结…

前置知识——Linux网络虚拟化

Linux网络虚拟化 信息是如何通过网络传输被另一个程序接收到的&#xff1f; 我们讨论的虚拟化网络是狭义的&#xff0c;它指容器间网络。 好了&#xff0c;下面我们就从 Linux 下网络通信的协议栈模型&#xff0c;以及程序如何干涉在协议栈中流动的信息来开始了解吧。 Linux…

基于飞桨实现的特定领域知识图谱融合方案:ERNIE-Gram文本匹配算法

文本匹配任务在自然语言处理领域中是非常重要的基础任务&#xff0c;一般用于研究两段文本之间的关系。文本匹配任务存在很多应用场景&#xff0c;如信息检索、问答系统、智能对话、文本鉴别、智能推荐、文本数据去重、文本相似度计算、自然语言推理、问答系统、信息检索等&…

【MySQL】了解MySQL的Explain,读这一篇够了( ̄∇ ̄)/

目录 ID select_type 查询类型 table 表名 type 关联类型/访问类型 possible_keys MySQL觉得可能要用到的索引 key 实际用到的索引 key_len 用到的索引的长度&#xff08;比如可用于判断使用了联合索引中的哪几个&#xff09; ref 表查找值所用的列&#xff08;表名.字…

Transformer在计算机视觉中的应用-VIT、TNT模型

上期介绍了Transformer的结构、特点和作用等方面的知识&#xff0c;回头看下来这一模型并不难&#xff0c;依旧是传统机器翻译模型中常见的seq2seq网络&#xff0c;里面加入了注意力机制&#xff0c;QKV矩阵的运算使得计算并行。 当然&#xff0c;最大的重点不是矩阵运算&…

行人车辆检测与计数系统(Python+YOLOv5深度学习模型+清新界面)

摘要&#xff1a;行人车辆检测与计数系统用于交通路口行人及车辆检测计数&#xff0c;道路人流量、车流量智能监测&#xff0c;方便记录、显示、查看和保存检测结果。本文详细介绍行人车辆检测&#xff0c;在介绍算法原理的同时&#xff0c;给出Python的实现代码、PyQt的UI界面…

【并发编程Python】一文详解Python并发编程,协程、线程、进程

并发编程简介和一些前缀知识 并发编程是使得程序大幅度提速的。在并发编程中&#xff0c;程序可以同一时间执行多个任务&#xff0c;这有助于提高程序的吞吐量和响应时间。并发编程设计的主要概念包括线程、锁、同步、信号量、进程间通信等。 前缀知识&#xff1a; IO&#x…

Linux中shell内外命令讲解(上)

♥️作者:小刘在C站 ♥️个人主页:小刘主页 ♥️每天分享云计算网络运维课堂笔记,努力不一定有收获,但一定会有收获加油!一起努力,共赴美好人生! ♥️夕阳下,是最美的绽放,树高千尺,落叶归根人生不易,人间真情 前言 本章Linuxshell讲解,感谢观看,干货满满。 目录…

在windows内使用virtualbox搭建安卓x86,以及所遇到的问题解决--2.virtualbox上安卓x86的配置

目录: 简要说明&#xff1a; 1.配置vesa驱动&#xff1a; 2.启用网络连接并配置adb&#xff1a; 3.增强性能的方法&#xff1a; 简要说明&#xff1a; 先进行说明一点个人直接通过vbox VMware这些软件&#xff0c;并不能超越专业的安卓模拟器&#xff0c;大部分模拟器实际…

使用Pytorch实现对比学习SimCLR 进行自监督预训练

SimCLR&#xff08;Simple Framework for Contrastive Learning of Representations&#xff09;是一种学习图像表示的自监督技术。 与传统的监督学习方法不同&#xff0c;SimCLR 不依赖标记数据来学习有用的表示。 它利用对比学习框架来学习一组有用的特征&#xff0c;这些特征…