学习笔记——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地址加上自己的掩码进行运算,最终计算出对端的网络地址

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

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

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

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

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

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


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

相关推荐
Nu11PointerException1 小时前
JAVA笔记 | ResponseBodyEmitter等异步流式接口快速学习
笔记·学习
_.Switch2 小时前
高级Python自动化运维:容器安全与网络策略的深度解析
运维·网络·python·安全·自动化·devops
qq_254674412 小时前
工作流初始错误 泛微提交流程提示_泛微协同办公平台E-cology8.0版本后台维护手册(11)–系统参数设置
网络
JokerSZ.2 小时前
【基于LSM的ELF文件安全模块设计】参考
运维·网络·安全
亦枫Leonlew3 小时前
三维测量与建模笔记 - 3.3 张正友标定法
笔记·相机标定·三维重建·张正友标定法
考试宝3 小时前
国家宠物美容师职业技能等级评价(高级)理论考试题
经验分享·笔记·职场和发展·学习方法·业界资讯·宠物
小松学前端4 小时前
第六章 7.0 LinkList
java·开发语言·网络
城南vision5 小时前
计算机网络——TCP篇
网络·tcp/ip·计算机网络
黑叶白树5 小时前
简单的签到程序 python笔记
笔记·python