1 主机、路由器网络层主要功能
2 IP数据报
2.1 图示
2.2 字段详细介绍
1)版本号
占4位:IP协议的版本号。4表示IPv4,6表示IPv6。
2)首部长度
占4位:表示IP分组首部长度。
以4字节为单位。如值为5,则表示首部长度为20字节(5*4=20)
3)服务类型TOS
占8位:指示期望获得哪种类型的服务
3 IP分片和重组
3.1 最大传输单元
3.2 链路MTU不同引发的问题

3.3 分片和重组
大IP分组向较小MTU链路转发时,可以被“分片” (fragmented)
1个IP分组分为多片IP分组IP分片到达目的主机后进行“重组”(reassembled)。注意,重组是到达目标主机后才进行的,在中间节点不会重组,原因很简单,如果分片了到达下一个路由器就重组,在下一次遇到最大输出单元较小的链路又得分片。
3.4 首部几个相关的字段
1)标识(ID)
占16位:标识一个IP分组

3)片偏移
占13位:一个IP分组分片封装原IP分组数据的相对偏移量。片偏移字段以8字节为单位。
如一个报文的大小为128,每个分组可以封装的数据为32,那么第一个分组的偏移量为0(32/8*(1-1)),第二个分组的偏移量为4(32/8*(2-1)),第三个分组的偏移量为8(32/8*(3-1)).......
3.5 分片过程
假设原IP分组总长度为L,待转发链路的MTU为M

每片的片偏移字段取值为:i表示第几个分片
每片的MF标志位为:
3.6 示例
4 IP编址
分为IPV4和IPV6,此处将IPV4
4.1 简介
IPV4地址长度是32位。由两部分组成,网络号和主机号。
通常写成10进制的200.221.222.101这种形式,便于使用和记忆。200.221.222就是网络号,101就是主机号。
4.2 IP子网
5 有类IP编址
5.1 IP分类
如下图,采用二分法把ip地址分为5类
A类地址,第一位是0的所有IP,占了全部IP的50%。它的前8位是网络号,后24位是主机号
B类地址,第一位是1,第二位是0的所有IP,占了全部IP的25%。它的前16位是网络号,后16位是主机号
C类地址,第一位是1,第二位是1,第三位是0的所有IP,占了全部IP的12.5%。它的前24位是网络号,后8位是主机号
D类地址,第一、二、三位是1,第四位是0的所有IP,占了全部IP的6.5%。不区分网络号和主机号。用来命令或标识Internet网络中一组主机。只能作为IP分组中的目的地址,不能作为发送地址。也叫作多波地址
E类地址,第一、二、三、四位是1的所有IP,占了全部IP的6.5%。不区分网络号和主机号。作为研究使用。
5.2 特殊的IP
5.3 私有IP地址
6 IP子网划分和子网掩码
6.1 子网再划分的原因
A类的网络号有8位,且第一位固定是0,所以A类的子网可以有2^7-1个。每个子网下面可以分配的ip数为2^24-1
B类的网络号有16位,且前两位固定是10,所以B类的子网可以有2^14-1个。每个子网下面可以分配的ip数为2^16-1=65535
C类的网络号有24位,且前三位固定是110,所以C类的子网可以有2^21-1个。每个子网下面可以分配的ip数为2^8-1=255
由此可见,A的子网数最少,但是每个子网可分配的ip最多
现在一个组织,有2000台主机,给他C类ip,才可以分配255个ip,肯定是不够的,给它一个B类ip,又太浪费,B类可分配65565个,而他只需要2000个,大量的ip浪费了。
所以,需要一种手段,把子网分成更小的子网。
6.2 子网号
在之前,ip地址分为网络号和主机号。现在,加上一个子网号。它占用原来的主机号的前几位来表示子网号,具体占用几位不固定。
通过网络号+子网号来表示一个更小的子网。
6.3 子网掩码
6.3.1 简介
子网掩码也是32位,形式和ip一样。
取值NetID、SubID位全取1,HostID位全取0
例如:A网的默认子网掩码为:255.0.0.0,B网的默认子网掩码为:255.255.0.0,C网的默认子网掩码为:255.255.255.0
借用3比特划分子网的B网的子网掩码为:255.255.224.0(11111111 11111111 11100000 00000000)
6.3.2 子网划分示例
子网201.2.3.0,255.255.255.0被子网掩码255.255.255.192(11111111 11111111 11000000 00000000)划分为4个等长的子网
201.2.3.0-201.2.3.63
201.2.3.64-201.2.3.127
201.2.3.128-201.2.3.191
201.2.3.192-201.2.3.255
6.3.3 路由怎么确定转发到哪个子网
将IP分组的目的IP地址与子网掩码按位与运算,提取子网地址
如:目的ip地址为172.32.1.112,子网掩码255.255.254.0
子网地址:172.32.0.0(子网掩码:255.255.254.0)
6.4 一个C类子网借用3位划分子网举例


7 CIDR和路由聚合
7.1 简介

7.2 示例
7.3 CRID的优点
由于Prefix可以任意长度,所以可以简单的自由划分任意大小的子网。也可以把多个子网合并成一个大的子网。
7.4 路由聚合示例

7.5 最长前缀匹配优先
如果,在路由转发表中匹配到多条记录,选取最长前缀(最具体)的那个范围
如路由转发表有下面两条记录
200.23.16.0/20 接口1
200.23.18.0/23 接口2
目标ip200.23.18.1,两个都可以匹配上,有限选择最长前缀的,所以选择接口2
8 DHCP协议
8.1 简介
DCHP(Dynamic Host Protocol),动态主机配置协议,是一个应用层协议。当我们将客户主机ip地址设置为动态获取方式时,DHCP服务器就会根据DHCP协议给客户端分配IP,使得客户机能够利用这个IP上网
8.2 主机获取ip地址
主机获取ip地址有两种方式
硬编码-静态配置
动态主机配置协议-DHCP: Dynamic Host ConfigurationProtocol,从服务器动态获取
8.3 静态配置
默认网关就是注意直接连接的路由器的公网ip地址,通过它可以连接网络
8.4 DHCP动态获取
8.4.1动态主机配置协议-DHCP简介
8.4.3 路由器和DCHP
现在的家用路由器都具备提供DHCP服务的能力,可以说现在的家用路由器是DHCP服务器、DNS 服务器、NAT服务器的集合体。
默认情况下路由器的DHCP服务器是启动的,并不需要用户进行配置。DHCP服务器给你连接该路由器上面的计算机分配IP地址、DNS服务器地址和默认网关地址。
9 网络地址转换NAT
9.1 简介
现在,我们日常生活中,计算机连接网络都是在一个路由器下的子网,且分配的都是私有ip,私有ip是不能直接和公网ip进行通信的,需要进行网络地址转换
如下图,右侧本地家庭网络都是采用的私有ip,想要与Internet进行通信,需要路由器进行一次网络地址转换。
10.0.0.1,10.0.0.2,10.0.0.3全部转换为138.76.29.7。那么,怎么区分来自哪台计算机呢,采用端口号来区分
9.2 网络地址转换(NAT)
9.3 NAT的实现
9.4 示例
9.5 NET端口号范围
tcp/udp端口仅仅是个标识数字,没有硬件上的意义,范围0-65535,NAT就利用它解决IP地址不足的问题。
所以NET可以同时支持605535个多并行连接
9.6 NET穿透问题
9.6.1 说明
如下图,在内网有个服务,这个内网外的其它用户想要访问它,该怎么访问呢
9.6.2 解决方法
1)静态配置NAT
将特定端口的连接请求转发给服务器 ,如配置(138.76.29.7, 2500) 总是转发给(10.0.0.1, 25000)
2)中继(如Skype)
NAT内部的客户与中继服务器建立连接
外部客户也与中继服务器建立连接
中继服务器桥接两个连接的分组
除了上面两种方法,还有其它的一些方法就不介绍了
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?