学习笔记——IP地址网络协议——网络掩码(Netmask)

三、网络掩码(Netmask)

1、网络掩码概述

网络掩码(Netmask)又称子网掩码(Subnet Mask)网络掩码为32 bit,与IP地址的位数一样,通常也以点分十进制数来表示。

子网掩码不能单独存在它必须结合IP地址一起使用。子网掩码只有一个作用,就是将某个IP地址划分成网络地址和主机地址两部分

说的通俗的话,就是用来分割子网和区分哪些IP是同一个网段的,哪些不是同一网段的

通常将网络掩码中1的个数称为这个网络掩码的长度。如∶掩码0.0.0.0的长度是0,掩码252.0.0.0的长度是6。

网络掩码一般与IP地址结合使用,其中值为1的比特对应IP地址中的网络位;值为0的比特对应IP地址中的主机位,来识别一个IP地址中的网络位与主机位。

即:网络掩码中1的个数就是IP地址的网络号的位数,0的个数就是IP地址的主机号的位数。

(1)子网掩码的组成

同IP地址一样,子网掩码是由长度为32位二进制数组成的一个地址。

子网掩码32位与IP地址32位相对应,IP地址如果某位是网络地址,则子网掩码为1,否则为0

IP地址:192.168.1.111 子网掩码:255.255.255.0

①转换为二进制 

1100 0000. 1010 1000. 0000 0001. 0110 1111   地址

1111 1111. 1111 1111. 1111 1111. 0000 0000   掩码

②子网掩码为1 所对应的IP地址那一位,则为网络位,子网掩码为0 所对应的位主机位。 24位网络位 8个主机位

注:左边连续的1的个数代表网络号的长度,(使用时必须是连续的,理论上也可以不连续),右边连续的0的个数代表主机号的长度。

(2)子网掩码的表示方法

①点分十进制表示法  二进制转换十进制,每8位用点号隔开

例如:子网掩码二进制11111111.11111111.11111111.00000000,表示为255.255.255.0

②CIDR斜线记法  IP地址/n

例1:192.168.1.100/24,其子网掩码表示为255.255.255.0,二进制表示为11111111.11111111.11111111.00000000

例2:172.16.198.12/20,其子网掩码表示为255.255.240.0,二进制表示为11111111.11111111.11110000.00000000

不难发现,例1中共有24个1,例2中共有20个1,所以n是这么来的。运营商ISP常用这样的方法给客户分配IP地址。

注:n为1到32的数字,表示子网掩码中网络号的长度,通过n的个数确定子网的主机数=2^(32-n)-2(-2的原因:主机位全为0时表示本网络的网络地址,主机位全为1时表示本网络的广播地址,这是两个特殊地址)。

在实际项目中,我们通常会遇到这样的IP地址。

  ip地址:192.168.1.1 子网掩码:255.255.255.0

  ip地址:192.168.1.2 子网掩码:255.255.255.0

案例1:我们可以直接的判断,他们是同属于一个网段的IP地址。那么对于下面这样的呢?

  ip地址:192.168.1.1 子网掩码:255.255.255.0

  ip地址:192.168.1.2 子网掩码:255.255.0.0

这两个ip地址虽然在不看掩码的情况下,比较像,但他们并不是同一个网段内的。这个可以从子网掩码来判断,

  192.168.1.1   255.255.255.0  是属于192.168.1.0网段。

192.168.1.2   255.255.0.0    是属于192.168.0.0网段。

2、子网掩码作用

①子网掩码(Subnet Mask)又叫网络掩码、地址掩码,必须结合IP地址一起对应使用。

②只有通过子网掩码,才能表明一台主机所在的子网与其他子网的关系,使网络正常工作。

③子网掩码和IP地址做“与”运算,分离出IP地址中的网络地址和主机地址,用于判断该IP地址是在本地网络上,还是在远程网络网上。

④子网掩码还用于将网络进一步划分为若干子网,以避免主机过多而拥堵或过少而IP浪费。

3、子网掩码的分类

(1)缺省(默认)子网掩码

缺省子网掩码(默认子网掩码),即未划分子网,对应的网络号的位都置 1 ,主机号都置 0 。

"有类编址"的地址划分过于死板,划分的颗粒度太大,会有大量的主机号不能被充分利用,从而造成了大量的IP地址资源浪费。

未做子网划分的IP地址:网络号+主机号

A类网络缺省子网掩码: 255.0.0.0,用CIDR表示为/8

B类网络缺省子网掩码: 255.255.0.0,用CIDR表示为/16

C类网络缺省子网掩码: 255.255.255.0,用CIDR表示为/24

(2)自定义子网掩码

将一个网络划分子网后,把原本的主机号位置的一部分给了子网号,余下的才是给了子网的主机号。即VLSM(Variable Length Subnet Mask),可变长子网掩码。将一个大的有类网络,划分成若干个小的子网,使得IP地址的使用更为科学,减少地址浪费。

做子网划分后的IP地址:网络号+子网号+子网主机号

举个栗子:192.168.1.100/25,其子网掩码表示:255.255.255.128

意思就是将192.168.1.0这个网段的主机位的最高1位划分为了子网。

4、网段

网段(network segment):在没有路由器的情况下,两个网络之间是不能进行TCP/IP通信的,

即使是两个网络连接在同一台交换机(或集线器)上,TCP/IP协议也会根据子网掩码(255.255.255.0)判定两个网络中的主机处在不同的网络里。

子网掩码和IP地址的关系

子网掩码是用来判断任意两台主机的IP地址是否属于同一网络的依据,就是拿双方主机的IP地址和自己主机的子网掩码做与运算,如结果为同一网络,就可以直接通信。

And按位与运算:

与运算是计算机中一种基本的逻辑运算方式,符号表示为&,也可以表示为 and。

参加运算的两个数据,按二进制位进行“与”运算。

运算规则:0&0=0;0&1=0;1&0=0;1&1=1;即:两位同时为“1”,结果才为“1”,否则为0

举例:192.168.1.1-192.168.1.2就是一个网段,类似于一个ip到另一个ip。是否同一网段判断:

要在同一网段,必须是网络标识(网络号)相同。

要想在同一网段,必需做到网络标识相同,那网络标识怎么算呢?

各类IP的网络标识算法都是不一样的。

A类的,只算第一段。

B类,只算第一、二段。

C类,算第一、二、三段。算法只要把IP和子网掩码的每位数AND(相与)就可以了。

AND方法:0 and 1=0; 0 and 0=0; 1 and 1=1;

如:192.168.0.1,255.255.255.0,先转换为二进制,然后AND每一位

IP : 192.168.0.1 -> 11000000.10101000.00000000.00000001

子网掩码: 255.255.255.0 -> 11111111.11111111.11111111.00000000

AND结果: 11000000.10101000.00000000.00000000 转换为十进制192.168.0.0,这就是网络标识

在实际项目中,我们通常会遇到这样的ip地址。

  ip地址:192.168.1.1 子网掩码:255.255.255.0

  ip地址:192.168.1.2 子网掩码:255.255.255.0

  我们可以直接的判断,他们是同属于一个网段的ip地址。那么对于下面这样的呢?

  ip地址:192.168.1.1 子网掩码:255.255.255.0

  ip地址:192.168.1.2 子网掩码:255.255.0.0

这两个ip地址虽然在不看掩码的情况下,比较像,但并不是同一个网段的。可以从子网掩码来判断

  192.168.1.1 255.255.255.0是属于192.168.1.0网段。

192.168.1.2 255.255.0.0是属于192.168.0.0网段。

如何根据掩码来确定ip地址网段

如何根据IP地址和子网掩码,计算网络地址:

将IP地址与子网掩码转换成二进制数。

②、将二进制形式的 IP 地址与子网掩码做“与”运算。

③、将得出的结果转化为十进制,便得到网络地址。

网络地址计算小技巧:IP地址和子网掩码做与运算,把IP地址的主机位直接归0,就快速得到网络地址。所以只要一看到IP地址和子网掩码,就能马上确认网络地址。

  ip地址:192.168.1.1 子网掩码:255.255.255.0

  ip地址:192.168.2.1 子网掩码:255.255.255.0

以上地址可以直观的判断,他们并不属于同一个网段,那么如何计算呢?

要想判断两个ip地址是不是在同一个网段,只需将ip地址与子网掩码做与运算,如果得出的结果一样,则这两个ip地址是同一个子网当中。

详细计算

  将ip地址192.168.1.1转换为二进制       11000000 10101000 00000001 00000001

  将子网掩码255.255.255.0转换成二进制   11111111.11111111.11111111.00000000

  将两者相“与(and)"运算得到结果:  11000000 10101000 00000001 00000000

  转换成网络号就是:             192   . 168    .       1. 0

  将ip地址192.168.2.1转换为二进制       11000000 10101000 00000010 00000001

  将子网掩码255.255.255.0转换成二进制   11111111.11111111.11111111.00000000

  将两者相“与(and)"运算得到结果:   11000000 10101000 00000010 00000000

  转换成网络号就是:             192    .168     .      2 . 0

二者的结果不一样,一个是网段192.168.1.0,一个是网段192.168.2.0,所以不是一个网段

例2:

ip地址1:192.168.1.1 子网掩码:255.255.252.0

ip地址2:192.168.2.1 子网掩码:255.255.252.0

详细计算

 将ip地址192.168.1.1转换为二进制         11000000 10101000 00000001 00000001

 将子网掩码255.255.252.0转换成二进制     11111111.11111111.11111100.00000000

 然后将两者相“与(and)"运算得到结果:    11000000 10101000 00000000 00000000

 转换成网络号就是:                          192     . 168     .  0     . 0

  将ip地址192.168.2.1转换为二进制          11000000 10101000 00000010 00000001

  将子网掩码255.255.252.0转换成二进制      11111111.11111111.11111100.00000000

  然后将两者相“与(and)"运算得到结果:  11000000 10101000 00000000 00000000

  转换成网络号就是:                       192   . 168     . 0     . 0

  很明显,二者的结果是一样的,都是属于192.168.0.0网段,所以他们是同属于一个网段。

如何根据ip地址推算子网掩码

大部分的情况下,网络中只要不超过254台主机的话,子网掩码都可以设置成255.255.255.0超过了254台主机的话怎么办呢?

可以划分vlan,也可以设置成一个大网段,划分vlan我们就不说了,上面有例子,设置成一个大网段就有一个难点,如何确定这个大网段里面的子网掩码呢?

例如:假设监控网络中有600个点位,我们不想把它划分vlan(实际项目中大部分是会划分vlan的),假设只想用一个大网段把这600个点位分配ip地址,如何设置ip地址,如何确实子网掩码?

分析:首先我们知道600个点位,可以使用3个254个ip地址段来分配。

ip段一:192.168.0.1——192.168.0.254

ip段二:192.168.1.1——192.168.1.254

ip段三:192.168.2.1——192.168.2.254  每个网段有254个ip地址,完全够600个点位用的。如果要使这三个ip段在同一个网段内,那么这个大网段共同的子网掩码是多少呢?分析下:

  将ip地址192.168.0.1转换为二进制       11000000 10101000 00000000 00000001

  将ip地址192.168.1.1转换为二进制       11000000 10101000 00000001 00000001

  将ip地址192.168.2.1转换为二进制       11000000 10101000 00000010 00000001

转换成了二进制,三个ip段的二进制前面22位的是不变的,那么可以将他们表示成:

  ip段一:192.168.0.1/22

  ip段二:192.168.1.1/22

  ip段三:192.168.2.1/22

这种192.168.2.x/22形式的ip地址相信大家平时都见过,就是已经告诉了子网掩码了。

也就是说他们共同的子网掩码二进制前面22个都是1。11111111 11111111 11111100 00000000

转换成十进制,那就是255.255.252.0,所以他们共同的子网掩码就是255.255.252.0。

通信时如何衡量是否在同一网段。

1、通信时发送端的主机会使用对方的IP地址加上自己的掩码进行运算,最终计算出对端的网络地址

2. 计算之后,将计算后的网络地址与自己本段的网络地址进行比对,相同,则认为在同一网段,不同,则认为不在同一网段。

5、有类和无类网络,超网和子网

有类网络(主类网络或标准网络):指把IP地址能归结到的A类、B类、C类IP,使用的是标准的默认子网掩码。

无类网络:相对于有类网络,无类网络IP地址的掩码是变长的。在有类网络的基础上,拿出一部分主机ID作为子网ID。

超网(SuperNetting)把多个小网络组合成一个大网络。

子网(Subnet):有类网络划分成更小后的网络。


整个华为数通学习笔记系列中,本人是以网络视频与网络文章的方式自学的,并按自己理解的方式总结了学习笔记,某些笔记段落中可能有部分文字或图片与网络中有雷同,并非抄袭。完处于学习态度,觉得这段文字更通俗易懂,融入了自己的学习笔记中。如有相关文字涉及到某个人的版权利益,可以直接联系我,我会把相关文字删除。【VX:czlingyun    暗号:CSDN】

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

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

相关文章

mysql 里面有rowid吗

在 MySQL 中,没有一个内建的、像 Oracle 数据库中那样的 ROWID 伪列。但是,MySQL 提供了几种方式来唯一地标识表中的行。 主键(PRIMARY KEY):每个表都可以有一个主键,它唯一地标识表中的每一行。主键的值在…

AI图片光影重塑 - IC Light独立安装

两个前提: 1.安装GIT (https://blog.csdn.net/qq_42372031/article/details/130676236) 2.安装ANACONDA(https://blog.csdn.net/ViatorSun/article/details/118578818) 来到IC-Light主页(https://github.…

品牌控价的同时也要做好数据分析

品牌在进行电商价格监测时,确实不应仅停留在收集低价数据的层面。在数据量巨大的今天,如何深度分析和挖掘这些数据的价值,为品牌的决策和战略提供有力支持,显得尤为重要。 首先,电商数据的监测和分析有助于品牌更全面…

Android14 WMS-IWindowSession介绍

IWindowSession客户端是应用,服务端是WMS。 官网介绍其作用是是“System private per-application interface to the window manager.”, 客户端通过IWindowSession向WMS发送请求,IWindowSession接口代码如下 /*** System private per-app…

函数高级:函数的默认参数|函数的占位参数|函数重载

函数的默认参数 函数占位参数 函数重载 总结: 函数的形参,有自己的参数值就用参数值,没有就用形参列表的默认值。 参数列表中,某位置有自己的默认值,从该位置起,往后就都必须设有默认值。 函数声明和函数…

详解MyBatis(二)

目录 1.MyBatis的基本操作 1.1增(Insert) 1.1.1返回主键 1.2删(Delete) 1.3改(Update) 1.4查(Select) 1.4.1起别名 1.4.2结果映射 1.4.3开启驼峰命名(推荐) 2.MyBatis XML配…

【Maxcompute】bd09、gcj02、wgs84经纬度坐标系转换udf函数

1.梳理、总结经纬度处理在Maxcompute平台上的实战应用,如bd09、gcj02、wgs84经纬度坐标系转换UDF函数注册与使用。 2.欢迎批评指正,跪谢一键三连! 文章目录 1.参考代码 1.参考代码 坐标系转换 bd09坐标系(百度坐标系)…

【Node】Node的Buffer模块介绍和使用

目录 简言Buffer模块Buffer和字符编码Buffer和 TypedArrays 缓冲区和类数组视图Buffers 和 iteration 缓冲区和迭代(遍历)Class: Blobnew buffer.Blob([sources[, options]]) 创建blob实例blob.arrayBuffer() 转换成ArrayBufferblob.size 数据大小blob.slice([start[, end[, ty…

我更看好开源大模型的发展前景

目录 开源大模型与闭源大模型,你更看好哪一方? 方向一:数据隐私 开源大模型: 闭源大模型: 方向二:商业应用 开源大模型: 闭源大模型: 方向三:社区参与 开源大模…

常用开关电源拓扑演进

目录 常用开关电源拓扑演进 一、概述 二、升压变换器(buck)与降压变换器(boost)

Oracle查看执行计划的方法

使用 EXPLAIN PLAN 命令: 首先,你需要执行 EXPLAIN PLAN FOR 你的查询语句。例如:EXPLAIN PLAN FOR SELECT * FROM employees WHERE department_id 10;然后,从系统表 PLAN_TABLE 中查询执行计划详情:SELECT * FROM TABLE(dbms_xp…

AR眼镜定制开发_在AR眼镜中实现ChatGPT功能

AR眼镜定制方案中,需要考虑到强大的算力、轻巧的设计和更长的续航时间等基本要求。然而,AR眼镜的设计方案不仅仅需要在硬件和显示技术方面取得突破,还要在用户体验方面有所进展。 过去,由于造价较高,AR眼镜的普及和商业…

Android 编译文件简述(Makefile 2)

Android 编译文件简述(Makefile 2) 承接上一篇Android 编译文件简述(Makefile),继续讲解Make使用方法。本篇文章简述Makefile的编译和执行流程控制。 作者:炭烤毛蛋 ,点击博主了解更多。 提示:了解Makefile 规则,构建Makefile变得简单。 文章目录 Android 编译文件简述(M…

按钮组切换控制统计图显示【统计图切换渲染失败】

背景 需要实现点击左上角按钮组的按钮,切换对应的统计图 点击按钮1呈现的统计图。映射的实体类Vo1 点击按钮2呈现的统计图。映射的实体类Vo2 可能会出现的问题: (1) 空白:进入页面只渲染第一个统计图,点…

TypeScript核心类型概览与应用-1

文章目录 TypeScript入门1.TypeScript介绍2.编译并运行TS代码2.1.简化运行ts步骤 3.TS中的常用类型3.1.TS中的类型注解3.2.TS中的原始类型3.3.TS中的数组类型3.4.TS中的联合类型3.5.类型别名3.6.函数类型3.6.1.单独执行参数、返回值类型3.6.2.同时指定参数,返回值类…

OpenGL系列(四)Shader

通过VBO和VAO准备好数据后,接下来要指示GPU如何通过这些数据绘制图形。类似CPU可以通过执行程序来完成特定的任务,GPU也可以执行特定的程序来完成绘制任务,GPU执行的程序称为Shader,也叫着色器。 GPU绘制图形分为不同的处理阶段&a…

09-使用JavaScript处理长列表数据:惰性渲染、虚拟滚动与分批渲染

使用JavaScript处理长列表数据:惰性渲染、虚拟滚动与分批渲染 笔记分享 在前端开发中,处理长列表数据是一项常见且具有挑战性的任务。为了提升性能和用户体验,开发者可以采用多种技术和方法来优化渲染过程。本文将介绍如何使用原生JavaScrip…

数据库课程设计mysql

数据库课程设计:MySQL 一、引言 数据库设计是数据库技术的一个重要方面,它涉及到数据的组织、存储、检索和管理。MySQL作为目前流行的关系数据库管理系统之一,广泛应用于各种应用场景中。本课程设计旨在通过MySQL平台,让学生深入…

深入探讨Qt中的容器类:QList与QVector

深入探讨Qt中的容器类:QList与QVector 在C的Qt框架中,容器类的选择对性能和内存使用有着重要影响。QList和QVector是Qt中两个常用的容器类,它们虽然在某些方面非常相似,但在实现细节和适用场景上存在显著差异。本文将详细介绍这两…

【Zero to One系列】SpringCloud Gateway结合Nacos完成微服务的网关路由

前期回顾&#xff1a; 【Zero to One系列】springcloud微服务集成nacos&#xff0c;形成分布式系统 1、Gateway依赖配置 主要Maven依赖如下&#xff1a; <dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>…