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

Docker 哲学 - ip 的组成规则 与 网关介绍

在 IP 地址中,我们通常将 IP 地址分为两部分:网络部分和主机部分。网络部分用于标识网络,主机部分用于标识该网络中的特定主机。

 IP 地址的每个部分(也被称为一个八位组或一个字节)可以是从0到255的任何值。

一个 IPv4 地址总共是 32 位。这 32 位被分为四个 8 位的部分,每个部分用一个点(.)分隔,这就是我们常说的点分十进制表示法。例如,在 IP 地址 192.168.1.0 中,1921681 和 0 分别是这四个 8 位部分的十进制表示。

一个字节(Byte)是计算机中的基本数据单位,它由8位(Bit)二进制数构成。每一位二进制数只有两种可能的值:0或1。

因此,一个字节有2的8次方,也就是256种可能的组合,这些组合可以表示从0到255的整数。这是因为我们通常从0开始计数,所以256种组合包括了0(当所有8位都是0时)和255(当所有8位都是1时)。

以下是一些例子:

  • 二进制数 00000000 对应的十进制数是 0。
  • 二进制数 00000001 对应的十进制数是 1。
  • 二进制数 00000010 对应的十进制数是 2。
  • 二进制数 00000011 对应的十进制数是 3。
  • ...
  • 二进制数 11111111 对应的十进制数是 255。

所以,一个字节可以用来表示一个0到255的整数。

二进制数是由0和1组成的数。在二进制数中,每一位的值取决于它的位置,也就是它的权重。最右边的位(也被称为最低位)的权重是2的0次方,然后向左每移动一位,权重就乘以2。

例如,二进制数 00000011 可以这样计算:

  • 最低位是1,权重是2的0次方,所以它的值是1 * 2^0 = 1。
  • 第二位也是1,权重是2的1次方,所以它的值是1 * 2^1 = 2。
  • 其他位都是0,所以它们的值都是0。

将这些值加起来,我们得到 1 + 2 = 3。所以,二进制数 00000011 对应的十进制数是3。

二进制数是由0和1组成的数。在二进制数中,每一位的值取决于它的位置,也就是它的权重。最右边的位(也被称为最低位)的权重是2的0次方,然后向左每移动一位,权重就乘以2。

例如,二进制数 11111111 可以这样计算:

  • 最低位是1,权重是2的0次方,所以它的值是1 * 2^0 = 1。
  • 第二位是1,权重是2的1次方,所以它的值是1 * 2^1 = 2。
  • 第三位是1,权重是2的2次方,所以它的值是1 * 2^2 = 4。
  • 第四位是1,权重是2的3次方,所以它的值是1 * 2^3 = 8。
  • 第五位是1,权重是2的4次方,所以它的值是1 * 2^4 = 16。
  • 第六位是1,权重是2的5次方,所以它的值是1 * 2^5 = 32。
  • 第七位是1,权重是2的6次方,所以它的值是1 * 2^6 = 64。
  • 最高位(最左边)是1,权重是2的7次方,所以它的值是1 * 2^7 = 128。

将这些值加起来,我们得到 1 + 2 + 4 + 8 + 16 + 32 + 64 + 128 = 255。所以,二进制数 11111111 对应的十进制数是255。

子网,或称为子网络,是一个逻辑上的IP网络划分。它允许一个组织内的网络被划分为多个小的网络,每个小的网络都被称为一个子网。

子网的主要目的是提高网络的效率和安全性。通过将一个大的网络划分为多个小的子网,可以减少网络流量,提高网络性能,同时也可以限制网络故障的影响范围。此外,子网还可以提供更好的安全性,因为可以控制子网之间的通信。

在IP地址中,子网掩码用于区分网络部分和主机部分。例如,IP地址 192.168.1.0/24 中,/24 是子网掩码,表示前 24 位是网络部分,后 8 位是主机部分。这个IP地址表示的是一个子网,这个子网中包含了 256 个IP地址,从 192.168.1.0 到 192.168.1.255

192.168.1.0/24 中的 /24 表示子网掩码,它决定了网络地址和主机地址的划分。在这个例子中,/24 表示前24位(即前三个八位组)是网络部分,后8位(即最后一个八位组)是主机部分。

网络部分 192.168.1. 是固定的,主机部分可以是 0 到 255,这就是为什么这个子网可以包含的 IP 地址范围是 192.168.1.0 到 192.168.1.255

具体来说,192.168.1.0 是这个子网的网络地址,192.168.1.255 是这个子网的广播地址,而 192.168.1.1 到 192.168.1.254 是这个子网中可用的主机地址。

192.168.1.0/24 这个表示法是 CIDR(无类别域间路由)表示法,其中 192.168.1.0 是网络地址,/24 是子网掩码。

在这个例子中,/24 表示前24位(即前三个数字)是网络部分,后8位(即最后一个数字)是主机部分。因此,这个子网可以包含的 IP 地址范围是 192.168.1.0 到 192.168.1.255

然而,192.168.1.0 通常被保留作为网络地址,192.168.1.255 通常被保留作为广播地址,所以实际可用的 IP 地址范围是 192.168.1.1 到 192.168.1.254

所以,当我们说 192.168.1.0/24 的子网包含了从 192.168.1.1 到 192.168.1.254 的所有 IP 地址时,我们是在说这个子网中实际可用的 IP 地址范围。

CIDR 的全拼是 Classless Inter-Domain Routing,中文通常翻译为无类别域间路由。

在 IP 地址中,我们通常将 IP 地址分为两部分:网络部分和主机部分。网络部分用于标识网络,主机部分用于标识该网络中的特定主机。

常见的网络和主机划分有:

  • /8:网络部分占用8位,主机部分占用24位。例如,10.0.0.0/8 的网络部分是 10.,主机部分是 0.0.0 到 255.255.255
  • /16:网络部分占用16位,主机部分占用16位。例如,172.16.0.0/16 的网络部分是 172.16.,主机部分是 0.0 到 255.255
  • /24:网络部分占用24位,主机部分占用8位。例如,192.168.1.0/24 的网络部分是 192.168.1.,主机部分是 0 到 255

这些划分方式允许我们在一个大的网络中创建多个小的子网络。每个子网络都有自己的网络地址,可以包含多个主机。

172.20.0.0/16 和 172.20.0.0/24 都是使用 CIDR(无类别域间路由)表示法的网络地址。其中,172.20.0.0 是网络地址,/16 和 /24 是子网掩码。

子网掩码决定了网络地址和主机地址的划分。在 172.20.0.0/16 中,/16 表示前16位(即前两个八位组)是网络部分,后16位(即后两个八位组)是主机部分。因此,这个子网可以包含的 IP 地址范围是 172.20.0.0 到 172.20.255.255

而在 172.20.0.0/24 中,/24 表示前24位(即前三个八位组)是网络部分,后8位(即最后一个八位组)是主机部分。因此,这个子网可以包含的 IP 地址范围是 172.20.0.0 到 172.20.0.255

所以,/16 和 /24 的主要区别在于子网的大小。/16 的子网比 /24 的子网大,因为它可以包含更多的 IP 地址。

 172.16.0.0/16创建子网 有什么方案

在 172.16.0.0/16 的网络中创建子网,你可以根据你的需求进行划分。以下是一些可能的方案:

  1. /24 子网:如果你需要大量的子网,每个子网中主机数量较少,你可以选择 /24 子网。这将会创建256个子网,每个子网可以有256个IP地址(其中4个IP地址被保留,实际可用的IP地址为252个)。子网范围将会是 172.16.0.0/24 到 172.16.255.0/24

  2. /20 子网:如果你需要适中数量的子网,每个子网中主机数量适中,你可以选择 /20 子网。这将会创建16个子网,每个子网可以有4096个IP地址(其中4个IP地址被保留,实际可用的IP地址为4092个)。子网范围将会是 172.16.0.0/20 到 172.16.240.0/20

  3. /16 子网:如果你只需要一个子网,每个子网中主机数量很多,你可以选择 /16 子网。这将会创建1个子网,子网可以有65536个IP地址(其中4个IP地址被保留,实际可用的IP地址为65532个)。子网将会是 172.16.0.0/16

如果你只需要一个子网,每个子网中主机数量很多,你可以选择 /16 子网。这将会创建1个子网,子网可以有65536个IP地址(其中4个IP地址被保留,实际可用的IP地址为65532个)。子网将会是 172.16.0.0/16。 那四个被占用。为什么不是 256 * 252 而是 256 * 256 - 4 

在一个 /16 的子网中,你有 256 * 256 = 65536 个 IP 地址。然而,并非所有的 IP 地址都可以分配给主机。有四个地址被保留用于特殊目的:

  1. 网络地址:这是子网的第一个地址,例如在 172.16.0.0/16 中,网络地址是 172.16.0.0。网络地址用于标识整个网络,不能分配给主机。

  2. 广播地址:这是子网的最后一个地址,例如在 172.16.0.0/16 中,广播地址是 172.16.255.255。广播地址用于在网络中发送广播消息,不能分配给主机。

  3. 子网的默认网关:通常,子网的第一个可用 IP 地址会被分配给子网的默认网关。例如,在 172.16.0.0/16 中,第一个可用的 IP 地址是 172.16.0.1

  4. 子网的网络服务地址:通常,子网的第二个可用 IP 地址会被分配给网络服务,例如 DHCP 或 DNS 服务器。例如,在 172.16.0.0/16 中,第二个可用的 IP 地址是 172.16.0.2

因此,虽然一个 /16 的子网有 65536 个 IP 地址,但实际可用的 IP 地址只有 65536 - 4 = 65532 个。

 如果你需要大量的子网,每个子网中主机数量较少,你可以选择 /24 子网。这将会创建256个子网,每个子网可以有256个IP地址(其中4个IP地址被保留,实际可用的IP地址为252个)。子网范围将会是 172.16.0.0/24 到 172.16.255.0/24。 那四个被占用

在一个 /24 的子网中,你有 256 个 IP 地址。然而,并非所有的 IP 地址都可以分配给主机。有四个地址被保留用于特殊目的:

  1. 网络地址:这是子网的第一个地址,例如在 172.16.0.0/24 中,网络地址是 172.16.0.0。网络地址用于标识整个网络,不能分配给主机。

  2. 广播地址:这是子网的最后一个地址,例如在 172.16.0.0/24 中,广播地址是 172.16.0.255。广播地址用于在网络中发送广播消息,不能分配给主机。

  3. 子网的默认网关:通常,子网的第一个可用 IP 地址会被分配给子网的默认网关。例如,在 172.16.0.0/24 中,第一个可用的 IP 地址是 172.16.0.1

  4. 子网的网络服务地址:通常,子网的第二个可用 IP 地址会被分配给网络服务,例如 DHCP 或 DNS 服务器。例如,在 172.16.0.0/24 中,第二个可用的 IP 地址是 172.16.0.2

因此,虽然一个 /24 的子网有 256 个 IP 地址,但实际可用的 IP 地址只有 256 - 4 = 252 个。

​​​​​​​

主机地址数量就是可用的IP地址数量。在一个子网中,主机地址是可以分配给设备(如计算机、打印机、路由器等)的IP地址。这些地址是子网中可用的IP地址,可以用于网络通信。 

解释 :172.16.0.0/20 

在 172.16.16.0/20 的子网中,/20 表示前20位是网络部分,后12位是主机部分。这意味着网络部分的最后一个八位组(也就是第三个八位组)只有前4位用于网络,后4位用于主机。

在 172.16.0.0/16 的网络中,我们可以创建16个 /20 子网。每个子网的大小是 16,所以子网的起始地址会每次增加 16。以下是这16个子网的列表,以及对应的第三个八位组的二进制表示:

  1. 172.16.0.0/20 - 0000 0000
  2. 172.16.16.0/20 - 0001 0000
  3. 172.16.32.0/20 - 0010 0000
  4. 172.16.48.0/20 - 0011 0000
  5. 172.16.64.0/20 - 0100 0000
  6. 172.16.80.0/20 - 0101 0000
  7. 172.16.96.0/20 - 0110 0000
  8. 172.16.112.0/20 - 0111 0000
  9. 172.16.128.0/20 - 1000 0000
  10. 172.16.144.0/20 - 1001 0000
  11. 172.16.160.0/20 - 1010 0000
  12. 172.16.176.0/20 - 1011 0000
  13. 172.16.192.0/20 - 1100 0000
  14. 172.16.208.0/20 - 1101 0000
  15. 172.16.224.0/20 - 1110 0000
  16. 172.16.240.0/20 - 1111 0000

每个子网都有 4096 个 IP 地址,其中 4 个 IP 地址被保留,所以实际可用的 IP 地址是 4092 个。 

4092 = 2^12 -  4 (172.16.0.0 、172.16.15.255   、 172.16.0.1、172.16.0.2 )

256 = 2^8

15 = 0000 1111 主机后四位最大是 15 

关于网关的 科学知识:

如果 172.20.0.3 和 172.20.0.4 都在同一个子网内(例如 172.20.0.0/24),那么它们之间的通信不需要通过网关。它们可以直接在本地网络内进行通信。

网关主要用于在不同的网络之间进行通信。例如,如果一个主机在 172.20.0.0/24 子网内,另一个主机在 172.21.0.0/24 子网内,那么它们之间的通信就需要通过网关。

网关在网络中起着桥梁的作用,它允许不同网络之间的通信。在计算机网络中,网关是一个硬件设备或者是一个软件程序,它在网络的边缘处工作,作为不同网络的连接点。

当一个网络中的设备(例如,一个在 172.20.0.0/24 子网内的主机)需要与另一个网络中的设备(例如,一个在 172.21.0.0/24 子网内的主机)通信时,它会将数据包发送到其网关。然后,网关会将这些数据包转发到目标网络。

因此,网关的主要作用是:

  1. 路由数据包:网关知道如何将数据包从源网络路由到目标网络。
  2. 协议转换:如果源网络和目标网络使用不同的网络协议,网关可以在这两种协议之间进行转换。
  3. 安全:网关可以提供防火墙和其他安全功能,以保护网络不受外部威胁。

总的来说,网关使得不同网络之间的通信成为可能。

相关文章:

Docker 哲学 - ip 的组成规则 与 网关介绍

在 IP 地址中,我们通常将 IP 地址分为两部分:网络部分和主机部分。网络部分用于标识网络,主机部分用于标识该网络中的特定主机。 IP 地址的每个部分(也被称为一个八位组或一个字节)可以是从0到255的任何值。 一个 IPv4…...

数学建模竞赛真的是模型解题一般,但是论文出彩而获奖的吗?

最近,数乐君发现有同学会有这样的问题:在数学建模国赛中,会因为参赛团队的模型解题一般,但论文写得非常精彩而获奖吗? 是的,确实会存在这样的情况。 我们都知道数学建模竞赛最终都是以提交成品论文的形式…...

深度学习常见的三种模型

深度学习模型实际上是一个包含多个隐藏层的神经网络,目前主要有卷积神经网络(CNN)、深度置信网络(DBN)、循环神经网络(RNN)。 1) 卷积神经网络 在机器学习领域,卷积神经网络属于前…...

接口自动化测试分层设计与实践总结

🍅 视频学习:文末有免费的配套视频可观看 🍅 关注公众号:互联网杂货铺,回复1 ,免费获取软件测试全套资料,资料在手,涨薪更快 接口测试三要素: 参数构造 发起请求&#x…...

集合(下)Map集合的使用

文章目录 前言一、Map接口二、Map接口的实现类 1.HashMap类2.TreeMap类总结 前言 Map集合没有继承Collection接口,不能像List集合和Set集合那样直接使用Collection接口的方法。Map集合其自身通过以key到value的映射关系实现的集合,也有相应的许多方法。类…...

AAPT: error: resource android:attr/dialogCornerRadius not found.

ERROR:D:\android.gradle\caches\transforms-3\b3b98118f65da38d0ad9da84cfc70a72\transformed\appcompat-1.0.0\res\values-v28\values-v28.xml:5:5-8:13: AAPT: error: resource android:attr/dialogCornerRadius not found. 请帮我看看这个错误是什么意思。我改如何做。 这个…...

数字功放VS模拟功放,选择适合你的音频解决方案

数字功放和模拟功放是音频系统中常用的两种功放技术,适用于不同的音频应用,都具有各自的优势和特点。本文将为您详细介绍数字功放和模拟功放的差异,并帮助您找到适合自己的音频解决方案。 1、数字功放是一种利用数字信号处理技术的功放。它将…...

5.88 BCC工具之tcpsynbl.py解读

一,工具简介 tcpsynbl工具以直方图的形式显示SYN到达时的TCP SYN积压大小。这可以让我们了解应用程序距离达到积压限制并丢弃SYN(导致SYN重传产生性能问题)还有多远。 TCP SYN 数据包则通常用于启动 TCP 三次握手过程的第一次握手。 二,代码示例 #!/usr/bin/env python…...

GVRP实现vlan的自动创建和注册

拓扑图 资源已上传 流程 第一、每台交换机的全局及端口下使能GVRP功能 第二、配置交换机的二层连通性,交换机某些端口配置Trunk端口,并允许相应的vlan通过 第三、在交换机4和5配置静态vlan100,然后查看1和3交换机是否有vlan100的定义&…...

Oracle VM VirtualBox修改磁盘大小

一、 修改虚拟机磁盘大小 先把虚拟机停掉。再增加磁盘大小。 路径中有空格的用""包起来。 D:\Program Files\Oracle\VirtualBox>VBoxManage.exe modifyhd "D:\Program Files\VirtualBox VMs\mycentos\mycentos.vdi" --resize 30000 0%...10%...20%...3…...

【嵌入式硬件】步进电机

1.步进电机简介 1.1步进电机基本原理 步进电机的英文是stepping motor。step的中文意思是行走、迈步。所以仅从字面上我们就可以得知,步进电机就是一步一步移动的电动机。说的官方一点儿,步进电机是一种将电脉冲信号转换成相应角位移或者线位移的电动机(直线电机)。下图为…...

FlyControls 是 THREE.js 中用于实现飞行控制的类,它用于控制摄像机在三维空间中的飞行。

demo演示地址 FlyControls 是 THREE.js 中用于实现飞行控制的类,它用于控制摄像机在三维空间中的飞行。 入参: object:摄像机对象,即要控制的摄像机。domElement:用于接收用户输入事件的 HTML 元素,通常…...

【Java程序设计】【C00366】基于(JavaWeb)Springboot的纹理生产图片系统(有论文)

TOC 博主介绍:java高级开发,从事互联网行业六年,已经做了六年的毕业设计程序开发,开发过上千套毕业设计程序,博客中有上百套程序可供参考,欢迎共同交流学习。 项目简介 项目获取 🍅文末点击卡片…...

编译原理Lab. 1 初代编译器实验说明和要求

目录 Lab. 1 初代编译器实验说明和要求一、初代编译器功能描述二、初代编译器文法要求三、初代编译器测试样例四、初代编译器提交要求五、初代编译器实验测试框架说明 代码与思路 Lab. 1 初代编译器实验说明和要求 一、初代编译器功能描述 初代编译器将 C 语言顺序语句序列翻…...

python判断工作日,节假日

一、概述 需要判断一个日期是否为工作日,节假日。 找到一个现成的插件,蛮好用的。 插件介绍 https://pypi.org/project/chinesecalendar/ 判断某年某月某一天是不是工作日/节假日。 支持 2004年 至 2020年,包括 2020年 的春节延长。 兼容…...

练习4-权重衰减(李沐函数简要解析)

环境:练习1的环境 代码详解 0.导入库 import torch from torch import nn from d2l import torch as d2l1.初始化数据 这里初始化出train_iter test_iter 可以查一下之前的获取Fashion数据集后的数据格式与此对应 n_train, n_test, num_inputs, batch_size 20, 100, 200, …...

websocket 中 request-line 中的URI编码问题

首先,request-line组成如下: Request-Line Method SP Request-URI SP HTTP-Version CRLF 在 rfc6455 规范的 5.1.2 Request-URI 中,有这样的描述: The Request-URI is transmitted in the format specified in section 3.2.1. …...

为何ChatGPT日耗电超50万度?

看新闻说,ChatGPT每天的耗电量是50万度,国内每个家庭日均的耗电量不到10度,ChatGPT耗电相当于国内5万个家庭用量。 网上流传,英伟达创始人黄仁勋说:“AI的尽头是光伏和储能”,大佬的眼光就是毒辣&#xff…...

__init__.py 的作用

在 Python 中,包含一个名为 __ init __.py 的文件的目录被称为一个包(package)。 __ init __.py 文件的作用有以下几点: 指示包含该文件的目录是一个 Python 包:当 Python 导入一个包时,会查找该包所在目录…...

Redis到底是多线程还是单线程?

Redis6.0之前:是单线程模式。 Redis6.0之后:Redis的IO线程是多线程,worker线程是单线程。 Redis6.0之前:单线程 Redis6.0之后:Redis的IO线程是多线程,worker线程是单线程。...

CMake基础:构建流程详解

目录 1.CMake构建过程的基本流程 2.CMake构建的具体步骤 2.1.创建构建目录 2.2.使用 CMake 生成构建文件 2.3.编译和构建 2.4.清理构建文件 2.5.重新配置和构建 3.跨平台构建示例 4.工具链与交叉编译 5.CMake构建后的项目结构解析 5.1.CMake构建后的目录结构 5.2.构…...

系统设计 --- MongoDB亿级数据查询优化策略

系统设计 --- MongoDB亿级数据查询分表策略 背景Solution --- 分表 背景 使用audit log实现Audi Trail功能 Audit Trail范围: 六个月数据量: 每秒5-7条audi log,共计7千万 – 1亿条数据需要实现全文检索按照时间倒序因为license问题,不能使用ELK只能使用…...

蓝牙 BLE 扫描面试题大全(2):进阶面试题与实战演练

前文覆盖了 BLE 扫描的基础概念与经典问题蓝牙 BLE 扫描面试题大全(1):从基础到实战的深度解析-CSDN博客,但实际面试中,企业更关注候选人对复杂场景的应对能力(如多设备并发扫描、低功耗与高发现率的平衡)和前沿技术的…...

[10-3]软件I2C读写MPU6050 江协科技学习笔记(16个知识点)

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16...

【单片机期末】单片机系统设计

主要内容:系统状态机,系统时基,系统需求分析,系统构建,系统状态流图 一、题目要求 二、绘制系统状态流图 题目:根据上述描述绘制系统状态流图,注明状态转移条件及方向。 三、利用定时器产生时…...

代码规范和架构【立芯理论一】(2025.06.08)

1、代码规范的目标 代码简洁精炼、美观,可持续性好高效率高复用,可移植性好高内聚,低耦合没有冗余规范性,代码有规可循,可以看出自己当时的思考过程特殊排版,特殊语法,特殊指令,必须…...

MySQL 部分重点知识篇

一、数据库对象 1. 主键 定义 :主键是用于唯一标识表中每一行记录的字段或字段组合。它具有唯一性和非空性特点。 作用 :确保数据的完整性,便于数据的查询和管理。 示例 :在学生信息表中,学号可以作为主键&#xff…...

(一)单例模式

一、前言 单例模式属于六大创建型模式,即在软件设计过程中,主要关注创建对象的结果,并不关心创建对象的过程及细节。创建型设计模式将类对象的实例化过程进行抽象化接口设计,从而隐藏了类对象的实例是如何被创建的,封装了软件系统使用的具体对象类型。 六大创建型模式包括…...

Elastic 获得 AWS 教育 ISV 合作伙伴资质,进一步增强教育解决方案产品组合

作者:来自 Elastic Udayasimha Theepireddy (Uday), Brian Bergholm, Marianna Jonsdottir 通过搜索 AI 和云创新推动教育领域的数字化转型。 我们非常高兴地宣布,Elastic 已获得 AWS 教育 ISV 合作伙伴资质。这一重要认证表明,Elastic 作为 …...

C++中vector类型的介绍和使用

文章目录 一、vector 类型的简介1.1 基本介绍1.2 常见用法示例1.3 常见成员函数简表 二、vector 数据的插入2.1 push_back() —— 在尾部插入一个元素2.2 emplace_back() —— 在尾部“就地”构造对象2.3 insert() —— 在任意位置插入一个或多个元素2.4 emplace() —— 在任意…...