计算机网络:IP协议详细讲解

目录

前言

一、IP网段划分

二、IP报头

三、解决IP地址不足-->NAT技术


前言

在之前,我们学习了传输层中的TCP和UDP,重点是TCP协议,他帮我们解决具体到主机的哪个应用(端口)、传输的可靠(序列号、校验和、流量控制、拥塞控制)、效率(滑动窗口、捎带应答、快重传)等问题。正式因为解决了这些问题,才使得应用层可以对网络中的数据更好的处理。

但是,我们并不清楚传输层报文是如何在网络中进行流动的,是如何能从一台主机,跨越那么多的网络到达另外一台主机的,而IP协议才真正解决了从哪里来,到哪里去的问题。网络层的主要任务是在复杂的网络环境中确定一个合适的路径

小总结:TCP提供可靠性的策略,IP具备从A到B的能力。他们两互相协作,让报文能可靠的从A到B。

一、IP网段划分

IP是一段地址,我们常说的192.168.1.1,这样的就是一个IP地址。

IP地址分为两个部分, 网络号和主机号
网络号: 保证相互连接的两个网段具有不同的标识;
主机号: 同一网段内, 主机之间具有相同的网络号, 但是必须有不同的主机号;

如下是我电脑的IP地址:192.168.121.1。

其中

  • 网络号:192.168.121.0(192.168.121.1按位与255.255.255.0)
  • 主机号:1(除去子网掩码的部分,剩下来的)

不同的子网其实就是把网络号相同的主机放到一起。

如果在子网中新增一台主机,则这台主机的网络号和这个子网的网络号一致,但是主机号必须不能和子网中的其他主机重复。

通过合理设置主机号和网络号,就可以保证在相互连接的网络中,每台主机的IP地址都不相同。

这样划分的好处就是一次可以筛选一大片,比如当前有一些数据需要发送到IP地址为192.168.122.1 的网络中,首先就看网络号是否相同,192.168.122.0与192.168.121.0网络号不相同,于是可以直接略过当前网络下的所有网络,直接往外部发送(路由器不仅仅连接着当前网络的所有主机,肯定还链接着外部网络,不然你家的网络从何而来)。

特殊的IP地址:

将IP地址中的主机地址全部设为0,就成为了网络号,代表这个局域网。

将IP地址中的主机地址全部设为1,就成为了广播地址,用于给同一个链路中相互连接的所有主机发送数据包。

二、IP报头

我们先来看一下IP报头,他里面的信息比较多

  • 4位版本号(version):指定IP协议的版本,对于IPv4来说,就是4。
  • 4位头部长度(header length):IP头部的长度是多少字节 。
  • 8位服务类型(Type Of Service):3位优先权字段(已经弃用), 4位TOS字段, 和1位保留字段(必须置为0). 4位 TOS分别表示:最小延时,最大吞吐量,最高可靠性,最小成本。这四者相互冲突, 只能选择一个。
  • 16位总长度(total length):IP数据报整体占多少个字节。
  • 8位生存时间(Time To Live, TTL):数据报到达目的地的最大报文跳数。
  • 8位协议:表示上层协议的类型。(传输层用的是TCP还是UDP还是其他)
  • 16位头部校验和:使用CRC进行校验,来鉴别头部是否损坏。
  • 32位源地址和32位目标地址: 表示发送端和接收端。
  • 选项字段(不定长,最多40字节):略,暂不考虑

其中,4位头部长度与16位总长度,能保证报头的分离。

8位协议能保证该报文会交送到传输层的哪个协议去处理。

8为生存时间,是为了让报文在网络中消散,因为报文可能会迷路,无法到达目的IP地址,如果存在大量报文在网络中一直不消散,就会造成网络阻塞,因此给报文设置生存时间,让无法到达目的IP消散。

还有16位标识、3位标志、13位片偏移,这似乎不好理解具体用处呀。

因为这涉及到数据链路层的工作,IP协议是一个指挥家,能够指挥报文从A到B,但具体干活的人是数据链路层的协议。如果从一台主机,发送了一条很长的数据,如果不进行分片,这条数据会一直占用网线、光纤这种设备,网络中的其他主机想要通信,这就会造成数据碰撞,导致数据被污染,无法进行传输,因此数据链路层就规定,我无法接收一串很长的报文,我会对其进行分片,也就是最大传输单元(MTU),一般为1500(字节)。

虽然数据链路层也会自动帮我们进行分片,但是如果跨越不同 MTU 的网络之间传输,就无法确保数据能够在多种不同类型的网络之间顺利传递。因此在上层分片之后,再交给下层是较为合理的。

  • 16 位标识符:用于标识一组属于同一数据包的分片。
  • 3 位标志:用来标识数据包是否可以分片,是否是最后一个分片等。
  • 13 位片偏移:用来指示某个分片在原始数据包中的位置。

也就是说16位标识、3位标志、13位片偏移是用来将大的报文拆分为较小的报文的****。

三、解决IP地址不足-->NAT技术

我们知道, IP地址(IPv4)是一个4字节32位的正整数。那么一共只有 2的32次方个IP地址,大概是43亿左右。而TCP/IP协议规定,每个主机都需要有一个IP地址。

随着互联网行业的兴起,很多设备都需要入网,如:电脑、手机、智能家居等等。那这个IPv4的地址肯定不够划分了,为何我们现在仍在使用IPv4呢?也没有感觉到地址不足的问题。

我们主要是利用了NAT技术来解决的。

要知道,我们的电脑绝大部分使用的是私网IP,他是可以重复的,私有 IP 地址只在局域网内部使用,不同局域网中的设备可以使用相同的私有 IP 地址,因为它们是相互隔离的,不会直接影响到其他网络。

那既然都是使用的私网IP,我们如何能够链接到外网呢?

我们的路由器有WAN口与LAN口。

LAN口(Local Area Network):表示连接本地网络的端口,主要用于家庭网络中的交换机,集线器或PC相连。

WAN口(Wide Area Network):表示连接广域网的端口,一般指互联网。

LAN口就是链接当前局域网下的机器,比如你家里的电脑网线就得插入到LAN口,这个IP地址会由路由器帮我们进行分配。如果当前主机(192.168.1.201)想要访问122.77.241.3,路由器会先帮我们查看,你要访问的网络是否在当前网络,发现网络号匹配不上,于是就将数据传输给WAN口,WAN口连接的是其他更大的网络(比如运营商的网络),再逐渐匹配,一直发送到公网上,到达对应的IP地址。

这样看,我们确实能够出去,访问到外部网络,外部网络如何能够回来呢?

他知道我们的IP地址为192.168.1.201,但是这个局域网的地址可以重复啊,他怎么知道是那个局域网的这个IP。

这是因为当有数据在路由器上进行转发时,每一个路由器都会生成一份NAT双向映射表,内部哪个IP:端口去了外部哪个IP:端口,并且再此过程还会一直修改源IP地址为路由器的WAN口IP

这样,公网的服务器收到了来自10.1.1.1路由器发来的数据,他处理完成后,也就可以向10.1.1.1发送响应,10.1.1.1路由器收到响应,查询NAT转化表,发现之前是122.77.241.3发来的数据,于是就往122.77.241.3发送该响应,就这样,直到发送到最开始的主机192.168.1.201上。

其实NAT转化表里面还有端口信息,比如一台主机打开了两个QQ,根据端口的不同,就能准确区分是哪一个QQ发送的数据。

这样就可以通过重复的私网IP,能访问到公网,公网的数据也能重回私网。

我们来分析一下NAT技术的好处

  1. 解决了IP地址不足的问题。
  2. 提高网络安全性,因为只有你先访问公网,先在路由器上建立了NAT转化表,公网才可以与你进行通信,这样一来,只要你不提前访问的情况下,就算黑客知道了你的IP地址,想要攻击你也不是一件容易的事。
相关推荐
南棱笑笑生17 分钟前
20241129解决在Ubuntu20.04下编译中科创达的CM6125的Android10出现找不到库文件
服务器·网络·windows
网络安全queen32 分钟前
不同云计算网络安全等级
服务器·网络·网络协议·网络安全
honey ball1 小时前
IIC和SPI的时序图
网络·单片机·嵌入式硬件·学习
Ljw...2 小时前
HTTP(网络)
linux·网络·网络协议·http
岑梓铭2 小时前
考研408《计算机网络》复习笔记,第二章《网络数据交换形式3大类》
笔记·计算机网络·考研
Tony聊跨境2 小时前
HTTPS的安全性优势
网络·网络协议·tcp/ip·http·https·ip
哥坐11路3 小时前
网工日记:NAT相关概念
运维·网络
小丁爱养花3 小时前
网络原理(二):HTTP 请求 - 首行 => 请求方法 & URL & 版本号
开发语言·网络·网络协议·http
帅比九日4 小时前
基于@ohos/axios深入学习HarmonyOS Next的网络数据请求
网络·学习·harmonyos