当前位置: 首页 > news >正文

[云原生1] Docker网络模式的详细介绍

1. Docker 网络

1.1 Docker 网络实现原理

Docker使用Linux桥接,在宿主机虚拟一个Docker容器网桥(docker0)
Docker启动一个容器时会根据Docker网桥的网段分配给容器一个IP地址,称为Container-IP
同时Docker网桥是每个容器的默认网关
因为在同一宿主机内的容器都接入同一个网桥,这样容器之间就能够通过容器的 Container-IP 直接通信

1.2 为容器创建端口映射

端口映射:底层原理实际是做了一个DNAT转换。

#基本格式
docker run -itd--name=为容器指定名称 -P 镜像名称
#示例
#方式1 ---- 随机映射端口(从32768开始)
docker run -d --name test1 -P nginx					

在这里插入图片描述

#方式2 ---- 指定映射端口
docker run -d --name test2 -p 43000:80 nginx	

在这里插入图片描述

2. Docker的网络模式概述

2.1 Docker的网络模式

  • Host: 容器不会虚拟出自己的网卡,配置主机的IP等,而是使用宿主机的IP和端口
  • Container: 创建的容器不会创建自己的网卡,配置自己的IP,而是和一个指定的容器共享IP,端口范围
  • None: 该模式关闭了容器的网络功能。
  • Bridge: 默认为该模式,此模式会为每一个容器分配,设置IP等,并将容器连接到一个docker0 的虚拟网桥,通过docker 0 网桥以及iptables nat 表配置与宿主机通信。
  • 自定义网络

在安装Docker 时,它会自动创建三个网络:bridge(创建容器默认连接到此网络),nonehost

2.2 查看docker的网络列表

 #查看docker的网络列表docker network ls或者docker network list

在这里插入图片描述

2.3 指定容器网络模式

#使用docker run创建Docker容器时,可以用 --net 或 --network 选项指定容器的网络模式- host模式:     使用 --net=host 指定。
- none模式:     使用 --net=none 指定。
- container模式:使用 --net=container:NAME_or_ID 指定。
- bridge模式:   使用 --net=bridge 指定,默认设置,可省略。

3. 网络模式详解

3.1 host模式

在这里插入图片描述

  • 相当于Vmware中的桥接模式,与宿主机在同一个网络中,但没有独立IP地址
  • Docker使用了Linux的Namespaces技术来进行资源隔离
  • 一个Network Namespace提供了一份独立的网络环境,包括网卡、路由、iptable规则等都与其他的Network Namespace隔离。
  • 一个Docker容器一般会分配一个独立的Network Namespace。 但如果启动容器的时候使用host模式,那么这个容器将不会获得一个独立的Network Namespace, 而是和宿主机共用一个Network Namespace。容器将不会虚拟出自己的网卡、配置自己的IP等,而是使用宿主机的IP和端口

容器和宿主机共享网络命名空间,但没有独立IP地址,使用宿主机的IP地址,和宿主机共享端口范围,例如宿主机使用了80端口,那么容器不能使用80端口。这种模式比较方便,但不安全

#示例
docker run --network=host

3.2 container模式

在这里插入图片描述

  • 这个模式指定新创建的容器和已经存在的一个容器共享一个Network Namespace,而不是和宿主机共享
  • 新创建的容器不会创建自己的网卡,配置自己的IP,而是和一个指定的容器共享IP、端口范围等
  • 同样,两个容器除了网络方面,其他的如文件系统、进程列表等还是隔离的
  • 两个容器的进程可以通过lo网卡设备通信
docker run --network=container:指定的容器ID|容器名
#示例
docker run -itd --name s1 nginx:1.12 /bin/bash			
#--name 选项可以给容器创建一个自定义名称docker ps -a

在这里插入图片描述

docker inspect -f '{{.State.Pid}}' 4a472c5865be
#查看容器的进程id号

在这里插入图片描述

docker run -itd --name s2 --net=container:4a472c5865be nginx:1.12 /bin/bashdocker inspect -f '{{.State.Pid}}' 3dc91d1b2eb7 
#查看新创建容器进程号

在这里插入图片描述

ls -l /proc/63713/nsls -l /proc/63613/ns
#查看两个容器的 net namespace 编号

在这里插入图片描述

3.3 none模式

在这里插入图片描述

使用none模式,Docker容器拥有自己的Network Namespace,但是,并不为Docker容器进行任何网络配置
也就是说,这个Docker容器没有网卡、IP、路由等信息。
这种网络模式下容器只有lo回环网络,没有其他网卡
这种类型的网络没有办法联网,封闭的网络能很好的保证容器的安全性

docker run -id --net=none --name s3 nginx:1.12
#指定网络模式为nonedocker inspect s3
#使用inspect查看

在这里插入图片描述

3.4 bridge模式

bridge模式是docker的默认网络模式,不用--net参数,就是bridge模式

在这里插入图片描述
相当于Vmware中的 nat 模式,容器使用独立network Namespace,并连接到docker0虚拟网卡。通过docker0网桥以及iptables nat表配置与宿主机通信,此模式会为每一个容器分配Network Namespace、设置IP等,并将一个主机上的 Docker 容器连接到一个虚拟网桥上。

  1. 当Docker进程启动时,会在主机上创建一个名为docker0的虚拟网桥,此主机上启动的Docker容器会连接到这个虚拟网桥上。

  2. 从docker0子网中分配一个IP给容器使用,并设置docker0的IP地址为容器的默认网关。在主机上创建一对虚拟网卡veth pair设备。

  3. Docker将 veth pair 设备的一端放在新创建的容器中,并命名为 eth0(容器的网卡),另一端放在主机中, 以 veth* 这样类似的名字命名, 并将这个网络设备加入到 docker0 网桥中。可以通过 brctl show 命令查看。

  4. 使用 docker run -p 时,docker实际是在iptables做了DNAT规则,实现端口转发功能。可以使用iptables -t nat -vnL 查看。

3.5 自定义网络模式

直接使用bridge模式,是无法支持指定IP运行docker的,例如执行以下命令就会报错

docker run -itd --name test3 --network bridge --ip 172.17.0.10 centos:7 /bin/bash

在这里插入图片描述

#创建自定义网络
docker network create --subnet 新网段 --opt "com.docker.network.bridge.name"="新网桥名" 新网络模式名docker run -id --network 新网络模式名 --ip 自定义IP#可以先自定义网络,再使用指定IP运行docker
docker network create --subnet=172.18.0.0/16 --opt "com.docker.network.bridge.name"="docker1"  mynetwork----------------------------------------------------------------------------------------------------------
#docker1 为执行 ifconfig -a 命令时,显示的网卡名,如果不使用 --opt 参数指定此名称,那你在使用 ifconfig -a 命令查看网络信息时,看到的是类似 br-110eb56a0b22 这样的名字,这显然不怎么好记。
#mynetwork 为执行 docker network list 命令时,显示的bridge网络模式名称。
---------------------------------------------------------------------------------------------

在这里插入图片描述

docker run -itd --name test4 --net mynetwork --ip 172.18.0.10 nginx:1.12 /bin/bash
#再次创建新容器docker inspect s4
#查看详细信息

在这里插入图片描述

相关文章:

[云原生1] Docker网络模式的详细介绍

1. Docker 网络 1.1 Docker 网络实现原理 Docker使用Linux桥接,在宿主机虚拟一个Docker容器网桥(docker0), Docker启动一个容器时会根据Docker网桥的网段分配给容器一个IP地址,称为Container-IP, 同时Docker网桥是每个容器的默认…...

uni——底部弹框显示,底部导航隐藏

案例 在uni-app中,如果你在tabbar页面显示一个底部弹框,底部导航默认是会依旧显示的。如果你想在弹框显示时隐藏底部导航,你可以使用uni.hideTabBar和uni.showTabBar方法来控制底部导航的显示和隐藏。 export default {methods: {openPopup(…...

HammerDB的安装和使用(超详细)

目录 ​编辑 一、HammerDB的介绍 二、HammerDB的安装 1、下载hammerdb安装包 2、权限配置以及安装 3、查看安装目录 三、安装前的配置 1、启动监听 2、启动数据库 3、创建表空间 1.修改临时表空间 2…...

java经典面试题总结

1.请简述Java的继承,重写和多态的概念和运用 继承是一种Java中重要的面向对象编程方式,它允许一个类从另一个类继承某些属性和方法,在这种关系下,子类可以重写父类的方法,从而实现不同的行为。 多态是继承实现的一种关…...

django中template中post请求接口csrf问题

$(function () {$.ajaxSetup({headers: { "X-CSRFToken": getCookie("csrftoken") }}); });// 为防止CSRF(Cross-site request forgery)跨站请求伪造,发post请求时需要在cookie中创建随机码 function getCookie(name) {v…...

聊聊RocketMQMessageListener的实现机制

序 本文主要研究一下RocketMQMessageListener的实现机制 示例 Service RocketMQMessageListener(nameServer "${demo.rocketmq.myNameServer}", topic "${demo.rocketmq.topic.user}", consumerGroup "user_consumer") public class UserC…...

ConfigurationProperties注解详解

ConfigurationProperties和Value注解用于获取配置文件中的属性定义并绑定到Java Bean或属性中 一个简单的例子 ConfigurationProperties需要和Configuration配合使用,我们通常在一个POJO里面进行配置: Data Configuration ConfigurationProperties(pre…...

三、组件与数据交互

一、组件基础 1、单文件组件 第一步&#xff1a;引入组件 import ComponentTest from ./components/ComponentTest.vue 第二步&#xff1a;挂载组件 components: {ComponentTest } 第三步&#xff1a;显示组件 <ComponentTest></ComponentTest><!-- 父组件 --…...

#define 宏定义看这一篇文章就够了

前言&#xff1a;在c/c学习的过程中&#xff0c;宏定义&#xff08;#define&#xff09;是作为初学者学习到的为数不多的预处理指令&#xff0c;在学习的时候我们被告知他可以帮助我们更高效的写程序&#xff0c;可以增加程序的可读性&#xff0c;但宏定义&#xff08;#define&…...

LeetCode算法栈—验证图书取出顺序

验证图书取出顺序 目录 验证图书取出顺序 题解&#xff1a; 代码&#xff1a; 运行结果&#xff1a; 验证图书取出顺序 现在图书馆有一堆图书需要放入书架&#xff0c;并且图书馆的书架是一种特殊的数据结构&#xff0c;只能按照 一定 的顺序 放入 和 拿取 书籍。 给定一个…...

PAM从入门到精通(十八)

接前一篇文章&#xff1a;PAM从入门到精通&#xff08;十七&#xff09; 本文参考&#xff1a; 《The Linux-PAM Application Developers Guide》 PAM 的应用开发和内部实现源码分析 先再来重温一下PAM系统架构&#xff1a; 更加形象的形式&#xff1a; 六、整体流程示例 2.…...

【区间 DP】热门区间 DP 运用题

题目描述 这是 LeetCode 上的 「312. 戳气球」 &#xff0c;难度为 「困难」。 Tag : 「区间 DP」、「动态规划」 有 n 个气球&#xff0c;编号为 0 到 n - 1&#xff0c;每个气球上都标有一个数字&#xff0c;这些数字存在数组 nums 中。 现在要求你戳破所有的气球。戳破第 i …...

正则表达式,日期选择器时间限制,报错原因

目录 一、正则表达式 1、表达式含义 2、书写表达式 二、时间限制 1、原始日期选择器改造 2、禁止选择未来时间 3、从...到...两个日期选择器的时间限制 三、Uncaught (in promise) Error报错 一、正则表达式 1、表达式含义 &#xff08;1&#xff09;/^([a-zA-Z0-9_.…...

YOLOv7 改进原创 HFAMPAN 结构,信息高阶特征对齐融合和注入,全局融合多级特征,将全局信息注入更高级别

💡本篇内容:YOLOv7 改进原创 HFAMPAN 结构,信息高阶特征对齐融合和注入,全局融合多级特征,将全局信息注入更高级别 💡🚀🚀🚀本博客 改进源代码改进 适用于 YOLOv7 按步骤操作运行改进后的代码即可 💡本文提出改进 原创 方式:二次创新,YOLOv7 专属 论文理…...

django建站过程(1)

django建站过程&#xff08;1&#xff09; 使用pycharm创建过程运行项目创建数据库创建超级用户登录生成的后台&#xff1a;界面本地化 准备以django,bootstrap来做一个过程记录&#xff0c;文章主要阐述过程的细节。 使用pycharm创建过程 创建项目“schoolapps”&#xff0c;…...

使用 Typhoeus 和 Ruby 编写的爬虫程序

以下是一个使用 Typhoeus 和 Ruby 编写的爬虫程序&#xff0c;用于爬取 &#xff0c;同时使用了 jshk.com.cn/get_proxy 这段代码获取代理&#xff1a; #!/usr/bin/env rubyrequire typhoeus require jsondef get_proxyurl "https://www.duoip.cn/get_proxy"respon…...

Git 安装和基础命令、IDEA 基础操作

目录 总结命令&#xff1a;1、安装&#xff1a;1、安装2、配置环境变量&#xff1a; 2、Git操作&#xff1a;1、初始化&#xff1a;1、姓名邮箱&#xff1a;2、初始化仓库&#xff1a;3、工作区和暂存区分析 2、提交文件3、查看版本库状态4、安装小乌龟git不显示图标 5、查看提…...

做一个最新版的淘宝客返利程序源码有多难?

我们都知道淘宝客返利程序成为了很多人的创业和赚钱的工具。这种程序允许通过推广淘宝商品来获得佣金。然而&#xff0c;你知道构建这样一个淘宝客返利程序有多难吗&#xff1f;今天我们就从最基本的API说起&#xff0c;现在我将介绍构建一个最新版淘宝客返利程序所需的关键API…...

day5:Node.js 第三方库

day5:Node.js 第三方库 文章目录 day5:Node.js 第三方库使用 Express.js 构建 Web 应用安装 Express第一个 Express 框架实例第二个 Express 框架实例Node.js 连接 MySQL查询数据插入数据更新数据删除数据使用 Express.js 构建 Web 应用 Express框架是Node.js生态系统中的一…...

如何正确停止线程?为什么 volatile 标记位的停止方法是错误的?

Java全能学习面试指南&#xff1a;https://javaxiaobear.cn 今天我们主要学习如何正确停止一个线程&#xff1f;以及为什么用 volatile 标记位的停止方法是错误的&#xff1f; 首先&#xff0c;我们来复习如何启动一个线程&#xff0c;想要启动线程需要调用 Thread 类的 start…...

别再死记GAN公式了!用‘警察与小偷’的故事5分钟搞懂损失函数

用"猫鼠游戏"理解GAN&#xff1a;当造假者遇上鉴伪大师 想象一下这样的场景&#xff1a;一位艺术品伪造大师&#xff08;生成器&#xff09;不断精进仿制技术&#xff0c;而博物馆鉴定专家&#xff08;判别器&#xff09;则持续升级检测手段——这种动态博弈正是生成…...

9款最佳AI表格工具深度评测:让数据处理效率翻倍的智能助手

在数据驱动决策的时代&#xff0c;Excel早已不是简单的电子表格&#xff0c;而是企业数据分析的核心战场。然而&#xff0c;面对海量数据和复杂公式&#xff0c;即便是Excel高手也难免头疼。AI技术的介入&#xff0c;正在彻底改变我们与表格交互的方式——从死记硬背公式到自然…...

终极指南:如何使用Klib的kseq.h高效处理FASTA/FASTQ格式数据

终极指南&#xff1a;如何使用Klib的kseq.h高效处理FASTA/FASTQ格式数据 【免费下载链接】klib A standalone and lightweight C library 项目地址: https://gitcode.com/gh_mirrors/kl/klib Klib是一个轻量级独立C库&#xff0c;其中的kseq.h模块为生物信息学数据处理提…...

把RK3568开发板变成网络摄像头:Android 11下UVC视频输出保姆级配置指南

将RK3568开发板改造为高性能网络摄像头的完整实战指南 手里闲置的RK3568开发板除了跑Demo还能做什么&#xff1f;今天我要分享一个极具实用价值的改造方案——将它变成一台支持UVC协议的网络摄像头。这个方案不仅成本低廉&#xff0c;还能充分发挥RK3568的硬件编解码能力&#…...

别光重启labelimg了!深入Python库目录,从根源搞定标注类别丢失和IndexError

深入Python库目录&#xff1a;从根源解决labelimg标注丢失与IndexError的技术侦探指南 当你第三次在深夜重启labelimg&#xff0c;却发现昨天标注的200张图片类别全部消失&#xff0c;命令行弹出刺眼的IndexError: list index out of range时&#xff0c;是时候放下鼠标&#x…...

AI专著生成全攻略:4款AI工具大揭秘,快速完成20万字专著写作!

学术专著的写作难点&#xff0c;不仅在于能否完成初稿&#xff0c;更在于是否能够成功出版并获得认可。在目前的出版市场中&#xff0c;学术专著的受众群体相对较小&#xff0c;这使得出版社在选题时对学术价值和作者的影响力都有着严格的要求。许多书稿即使完成了初步的写作&a…...

软件开发的架构设计中 分包、分模块的目的

分包与分模块的核心目的在于实现业务功能的解耦、优化与复用&#xff0c;以应对软件系统日益增长的复杂性。 目的与价值 职责分离与专注度提升&#xff1a;将庞大复杂的业务系统拆分为独立模块&#xff08;如商品模块、订单模块、用户中心模块&#xff09;&#xff0c;使每个模…...

5步掌握DoL-Lyra整合包:从零构建个性化游戏体验的完整指南

5步掌握DoL-Lyra整合包&#xff1a;从零构建个性化游戏体验的完整指南 【免费下载链接】DOL-CHS-MODS Degrees of Lewdity 整合 项目地址: https://gitcode.com/gh_mirrors/do/DOL-CHS-MODS Degrees of Lewdity中文模组整合包&#xff08;DOL-CHS-MODS&#xff09;是一个…...

OpenWrt V23.05安全加固:修改默认UI登录用户的完整流程

OpenWrt V23.05安全加固&#xff1a;修改默认UI登录用户的完整流程 在网络安全日益重要的今天&#xff0c;路由器作为家庭和企业网络的第一道防线&#xff0c;其安全性不容忽视。OpenWrt作为一款开源的嵌入式操作系统&#xff0c;因其高度可定制性和强大的功能而广受欢迎。然而…...

GitHub多领域资源大揭秘:AI、开发技能、工程技术等应有尽有!

【GitHub资源导航】这里有GitHub的相关链接&#xff0c;如GitHub主页、博客、更新日志、文档、客户案例等&#xff0c;还可试用GitHub Copilot和查看最新动态。【人工智能与机器学习】可了解GitHub生态系统及更广泛行业中的人工智能和机器学习知识&#xff0c;包括生成式AI、Gi…...