【网络原理】IP协议

【IP协议结构】

【8位生存时间(TTL)】

一个数据包在网络中最多存活多长时间

假设构造一个IP数据包,目的IP写错了,写成了不存在的IP,若让这样的数据包无限传输,会消耗很多的网络资源

TTL约定了传输时间的上限,达到上限后,数据包会自动被丢弃掉

TTL的单位是**"次数"**,指的是经过路由器转发的次数

发送一个IP数据包时,会有一个初始的TTL的值(32,64,128......),数据包每经过一个路由器转发,TTL就会-1(经过交换机不减),一旦TTL减到0,此时这个数据包会被当前的路由器丢弃掉

【8位协议】

分辨IP数据包中携带的载荷,是哪种传输层协议的数据包

通过这里的不同数值,感知到接下来要把数据交给什么样的协议进行解析

【16位首部检验和】

验证数据在传输中是否出错(只针对首部,IP报头,载荷部分TCP/UDP都有自己的校验和)

【32位原IP地址,32位目的IP地址】

IP数据包中最关键的信息,表明数据从哪里来,到哪里去

IP地址,用来标识网络上的一个设备,期望IP地址是唯一的,但如今可以上网的设备太多,IP不够用

一台电脑上,有几个网卡,就有几个IP,硬件网卡只能有一个,但虚拟网卡却可以虚构出来

【解决IP不够用的问题】

方案一:动态分配IP地址

一个设备上网就分配IP,不上网就先不分配

但这只是权宜之计

方案二:NAT(网络地址转换)

使用一个IP代表一大波设备

------------IP分类------------------------

把IP地址分为两大类

1.内网IP/私网IP**(10.*或172.16-172.31.*或192.168.*)**

2.外网IP/公网IP

要求:公网IP必须唯一,但私网IP允许重复(在不同的局域网中允许重复)


一个设备在上网时,IP数据包中的IP地址,会被NAT设备(通常是路由器)进行自动修改

1.同一个局域网内,主机A访问主机B,不会涉及到NAT机制

2.公网上的设备A,访问公网上的设备B,不会涉及到NAT

3.一个局域网中的主机A访问另一个局域网的主机B,NAT机制中不允许

4.局域网内部设备A,访问公网上的设备B,NAT机制主要针对这个情况生效

局域网内部设备A访问公网上设备B时,会途径具有公网IP的运营商路由器,此时运营商路由器会把A的源IP地址替换为该公网IP

运营商路由器在进行IP替换时,会记录旧IP旧端口和新IP新端口之间的映射关系

方案三:IPv6 【最好的方案】

从根本上解决IP地址不够用的问题

IPv4使用32位4个字节表示IP地址

IPv6使用128位16个字节表示IP地址

因此IPv6的地址空间非常巨大

【IP地址结构】

IP地址是一个32位的整数,左半部分是网络号,右半部分是主机号,如何判断左半部分和右半部分的界限?需要用到**"子网掩码"**

子网掩码也是一个32位的整数,左半部分都是1(二进制形式都是1),右半部分都是0

255.255.255.0通过二进制可以转换为

(也可以缩写为/24,代表有24个1)

因此,该图中IPv4地址,192.168.100是网络号,152是主机号

网络中规定:

同一个局域网中的设备,网络号必须相同,主机号必须不同

两个相邻的局域网,网络号必须不同

在该图这个局域网中,网络号不相同的设备(网络号不是192.168.0)无法上网,网络号相同的设表,如果主机号相同,也无法上网

此外,路由器有两个网络接口,一个LAN口,一个WAN口

相关推荐
大隐隐于野6 小时前
tcp 丢包分析
linux·服务器·网络
qqxhb7 小时前
系统架构设计师备考第64天——网络构建关键技术
网络·系统架构·mtbf·mttr·冗余硬件·软件热备·快速检测
哈乐11 小时前
网工应用题:配置命令补全类题目
服务器·前端·网络
张人玉11 小时前
C# TCP 服务器和客户端
服务器·tcp/ip·c#
雯0609~11 小时前
宝塔配置:IP文件配置,根据端口配置多个项目文件(不配置域名的情况)
服务器·网络协议·tcp/ip
梁正雄11 小时前
19、docker跨主机网络 Overlay\Underlay
网络·docker·容器
沧澜sincerely11 小时前
运输层协议概述及UDP
网络·udp·运输层
国科安芯12 小时前
抗辐照MCU芯片在无人叉车领域的性能评估与选型建议
网络·人工智能·单片机·嵌入式硬件·安全
国科安芯12 小时前
抗辐照MCU芯片在激光雷达领域的适配性分析
网络·人工智能·单片机·嵌入式硬件·fpga开发
xixixi7777712 小时前
水坑攻击的攻击原理和特点+案例和防御方法
网络·安全·web安全