当前位置: 首页 > article >正文

【JavaEE】IP协议 应用层协议

 🔥个人主页: 中草药

🔥专栏:【Java】登神长阶 史诗般的Java成神之路


🕶️一.IP地址

         IP协议(Internet Protocol)是TCP/IP协议族中最核心的协议之一,它定义了数据包在网络中传输的标准和规则。IP协议的设计初衷是为了实现大规模、异构网络的互联互通,并且分割了顶层网络应用和底层网络技术之间的耦合关系,以促进两者的独立发展 

我们这里研究的是IPv4 

  • 主机:配有IP地址
  • 路由器 :配有IP地址,并能进行路由选择
  • 节点:主机和路由器的统称

🥽二.报头格式

IPv4报头结构如下所示:

  1. 版本(Version, 4位) - 指定使用的IP协议版本。只有两个取值,4和6,对于IPv4,这部分值为4。
  2. 首部长度(Header Length, 4位) - 指明 报头的长度,以32位字(4字节)为单位。
  3. 服务类型(Type of Service, TOS, 8位) IP协议以那种模式进行工作,包含区分服务字段,用于描述数据包的优先级和其他服务质量要求。
  4. 总长度(Total Length, 16位) - 表示整个IP数据报的长度,以字节为单位。
  5. 标识(Identification, 16位) - 用于识别属于同一数据报的所有分片。涉及到组包拆包。
  6. 标志(Flags, 3位) - 主要用来控制分片行为。
    • 最高位(保留未使用)
    • 中间位(Don't Fragment, DF):表示当前是否是拆包/组包
    • 最低位(More Fragments, MF):表示当前包,是否是组包中的最后一个。
  7. 分片偏移(Fragment Offset, 13位) - 决定组包时候的先后顺序。
  8. 生存时间(Time to Live, TTL, 8位) - 数据报在网络中可以存在的最长时间,每经过一个路由器 TTL(不是s或者min,而是次数) 减一,当TTL为0时数据报将被丢弃。假设构造的一个IP数据报,目的IP不存在,如果让这样的数据报,无限传输,会消耗很多网络资源。
  9. 协议(Protocol, 8位) - 指明上层使用的协议类型,是传输给TCP还是UDP等。
  10. 头部校验和(Header Checksum, 16位) - 用于检测数据在传输中是否出错。
  11. 源IP地址(Source IP Address, 32位) - 发送方的IP地址。
  12. 目标IP地址(Destination IP Address, 32位) - 接收方的IP地址。
  13. 选项(Options) - 可选字段,用于携带特定的控制信息或实验用途。
  14. 填充(Padding) - 如果需要的话,用来确保报头的长度为32位的整数倍。

🥼三.版本

IP协议有两个主要版本:IPv4和IPv6。

  • IPv4 使用32位地址,这种地址空间随着互联网的扩张而逐渐耗尽
  • IPv6 采用128位地址,极大地扩展了地址空间,并引入了一些新的特性,如内置的安全性(如IPsec)和支持即插即用的自动配置

🦺四.主要功能

  • 地址管理:为网络上的每一个设备分配一个唯一的地址(即IP地址),从而使得数据可以在网络中被路由到正确的接收者
  • 路由选择:IP协议决定了数据包在网络中传输的最佳路径。这涉及到根据网络拓扑选择合适的路径,以确保数据包能够高效地到达目的地

👔五.IP地址

        IP地址,用来标识网络上的一个设备,期望的IP地址应该是唯一的,32位表示的数据范围是,0->42亿9千万,这样的数字在如今“移动互联网” “物联网” 时代已经不够用了,因此解决IP地址不够用的问题我们有三个方案

1.动态分配IP地址

         若设备上网就分配IP地址,不上网就不分配地址

2.NAT 网络地址转换

        NAT的核心思想是在一个网络边界路由器上维护一个地址转换表,这个表记录了内部私有IP地址与外部公有IP地址之间的映射关系。当内部网络中的设备需要与外部网络通信时,NAT会将数据包的源IP地址替换为公共IP地址,并且可能会改变源端口号来区分不同的会话。

  • 同一个局域网内,主机A访问主机B,不会涉及到NAT
  • 公网上的设备A,访问公网上的设备B,不会涉及到NAT
  • 一个局域网的主机A访问另一个局域网的主机B,NAT机制不允许
  • 局域网上的设备A,访问到公网上的设备B,主要涉及到NAT机制

当内部网络中的设备发送请求到外部网络时:

  1. 数据包到达NAT设备。
  2. NAT设备检查其转换表以找到相应的条目。
  3. 如果没有找到,则创建一个新的条目,并将内部私有IP地址和端口号替换为NAT设备上的公共IP地址和一个新的端口号。
  4. 修改后的数据包被转发到互联网。

对于从外部网络到内部网络的数据包,NAT设备会根据其转换表逆向操作,将公共IP地址和端口号转换回内部私有IP地址和端口号。

优点

  • 节约IP地址:通过使用私有IP地址范围(如10.x.x.x, 172.16.x.x - 172.31.x.x, 192.168.x.x),可以大大减少对全球唯一IP地址的需求。
  • 安全性:NAT可以隐藏内部网络结构,从而增加了一定程度的安全性。
  • 灵活性:可以轻松地添加新的内部主机而不需要重新配置它们的IP地址。

缺点

  • 性能开销:NAT需要处理额外的数据包头部修改工作,这可能会带来一些性能上的影响。
  • 协议支持:某些协议可能依赖于特定的端口行为或者需要透明地传输IP地址信息,这些情况下NAT可能会导致问题。
  • 复杂性:在NAT机制的网络环境是非常复杂的,随着网络规模的增长,管理NAT表可能会变得复杂。

 3.IPv6

该方法从根本原因解决了 IP地址不够分配的原因

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

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

除非未来人类的文明急速发展走向宇宙,否则只要人类困到地球上,IPv6足够人类用一辈子

IPv6与IPv4并不兼容,现如今IPv6在国内的普及程度非常高,已经超过70%

特殊的IP地址

1.主机号全为0

此时这个IP就表示当前网段(相当于网络号)

因此,再给局域网某个设备分配IP地址的时候,不能把主机号设置为全为0

2.主机号全为1

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

3.127.*  环回IP(lookback)

自发自收,给这个ip发一个数据,使用环回Ip用于测试,网络程序大多是跨主机通信,往往先自行测试,一台主机的测试客户端和服务器之间鞥否正常交互

🎒六.网段划分

        IP地址的网段划分指的是将一个大的IP地址范围细分为多个小的子网的过程,也叫组网(组建网络)。这样做可以提高网络效率,简化网络管理,并有助于更好地控制网络流量。

组网的时候,需要我们针对每个上网的设备的IP地址进行设置,对于家庭网络这种相对简单的网络结构都有自动分配IP地址,针对如同商场,学校这种更复杂的网络环境,需要手动设置

子网掩码

为了确定一个IP地址的哪一部分是网络号,哪一部分是主机号,我们使用子网掩码(subnet mask)。子网掩码也是一个32位的二进制数,同样表示为点分十进制形式。它与IP地址进行按位与运算(AND operation),以确定网络号和主机号。

例如,对于IP地址192.168.1.1,如果子网掩码是255.255.255.0,则网络号是前三个八位字节192.168.1,而主机号是最后一个八位字节1。网络掩码也是32位的整数,左半部分都是1,右半部分都是0,不能0 1穿插出现

网络中规定:

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

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

过去提过一种花粉网络号和主机号的方案,把所有的IP地址划分为五类

  • A类 0.0.0.0到127.255.255.255
  • B类 128.0.0.0到191.255.255.255
  • C类 192.0.0.0到223.255.255.255
  • D类 224.0.0.0到239.255.255.255
  • E类 240.0.0.0到247.255.255.255

其中AB类的主机号太多了,实际上一般没有这么大的局域网,这属于上古网络时期的网络划分时代,现在基本上已经没有了

CIDR(无类别域间路由)

        CIDR(Classless Inter-Domain Routing)是一种用于替代传统分类网络的IP地址分配方式。它允许管理员使用斜杠表示法(如192.168.1.0/24),其中斜杠后面的数字代表子网掩码中的网络位数。例如,/24意味着前24位用于网络号,剩下的8位用于主机号。主要用途如下:

引入一个额外的子网掩码类区分网络号和主机号

将IP地址和子网掩码进行“按位与”操作得到的是网络号

        通过使用CIDR,可以更加有效地利用IP地址空间。例如,一个/24的子网可以进一步划分为两个/25的子网,或者四个/26的子网等等,直到满足所需的主机数量为止。

🧢七.路由选择

        IP地址的路由选择是指在网络中决定数据包从源地址到目的地址的最佳路径的过程。路由选择涉及到路由器如何决定数据包应该通过哪个接口转发,以及如何将数据包发送到最终的目的地。下面是关于IP地址路由选择的一些详细信息:

        路由选择的核心是路由器如何选择合适的路径将数据包从源地址传递到目的地址。路由器使用路由表来存储关于可达网络的信息,包括下一跳地址、出站接口、度量值等。当路由器接收到数据包时,它会查找路由表来确定如何转发数据包。

路由表的组成

路由表是路由器内部维护的重要数据,可以类似理解为hash表,key相当于IP地址(网络号),value相当于对应的网络接口(往哪个方向走)

路由表通常包含以下几个要素:

  • 前缀(Prefix):目标网络的地址及其子网掩码。
  • 下一跳(Next Hop):路由器应该将数据包转发到的下一个路由器的IP地址。
  • 出站接口(Interface):路由器上用来转发数据包的物理接口。
  • 度量值(Metric):用于评估路径优劣的标准,不同路由协议使用不同的度量值,如跳数、带宽、延迟等。
  • 路由来源(Source):路由信息的来源,可能是直连网络、静态路由或动态路由协议

路由的过程,是“跳一跳”的问路过程

所谓的一跳,就是在数据链路层的中的一个区间,具体在以太网从源MAC地址到目的MAC地址之间的帧传输空间

IP数据包的传输过程也和问路一般

  • 当IP数据包到达路由器时,路由器先会查看目的IP
  • 路由器决定这个数据包是能够直接发送给目标主机,还是需要发送给下一个路由器
  • 依次反复,一直到达目标 IP 地址

💎八.总结与反思

我从来不知道什么是苦闷,失败了再来,前途是自己努力创造出来的。——徐特立

简介

IP协议是一种无连接、尽最大努力交付的协议,它负责将数据从源主机传输到目的主机。IP协议定义了数据包的格式,并规定了如何将数据包发送到目的地。IP协议有两个主要版本:IPv4和IPv6,两者都在当今的网络环境中发挥着重要作用。

IPv4

IPv4是最早的IP协议版本,它使用32位地址,可以提供大约43亿个唯一的地址。尽管IPv4在互联网发展的早期阶段表现良好,但随着互联网用户的快速增长,IPv4地址资源逐渐耗尽。

IPv6

为了解决IPv4地址短缺的问题,IPv6应运而生。IPv6使用128位地址,提供了几乎无限的地址空间。此外,IPv6还引入了一些新的特性,如内置的安全性和自动配置能力。

IP数据报格式

无论是IPv4还是IPv6,数据报(Datagram)都是IP协议处理的基本单位。数据报包含头部信息和用户数据两部分。

IPv4数据报

  • 版本(Version):指明所使用的IP协议版本。
  • 头部长度(IHL):指示头部的长度。
  • 服务类型(TOS):现在通常用于区分服务等级。
  • 总长度(Total Length):整个数据报的长度。
  • 标识符(Identification):用于标识数据报。
  • 标志(Flags):指示是否允许分片。
  • 片段偏移(Fragment Offset):如果数据报被分片,指示各片段的相对位置。
  • 生存时间(TTL):数据报在网络中的存活时间。
  • 协议(Protocol):指示高层协议类型。
  • 头部校验和(Header Checksum):用于检测头部中的错误。
  • 源IP地址(Source IP Address):发送数据报的源地址。
  • 目的IP地址(Destination IP Address):接收数据报的目的地址。
  • 选项(Options):可选字段,用于实验或特殊用途。
  • 填充(Padding):使头部长度为32比特的整数倍。

IPv4是最早的IP协议版本,它使用32位地址,可以提供大约43亿个唯一的地址。尽管IPv4在互联网发展的早期阶段表现良好,但随着互联网用户的快速增长,IPv4地址资源逐渐耗尽。

IPv6

为了解决IPv4地址短缺的问题,IPv6应运而生。IPv6使用128位地址,提供了几乎无限的地址空间。此外,IPv6还引入了一些新的特性,如内置的安全性和自动配置能力。

        IP协议作为TCP/IP模型中的网络层协议,是互联网技术的基石之一。它定义了数据在网络中的传输方式,使得世界各地的设备能够相互通信。随着IPv6的普及,IP协议将继续支撑着互联网的持续发展。


🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀

以上,就是本期的全部内容啦,若有错误疏忽希望各位大佬及时指出💐

  制作不易,希望能对各位提供微小的帮助,可否留下你免费的赞呢🌸


http://www.kler.cn/a/306518.html

相关文章:

  • 什么是数字图像?
  • 普通电脑上安装属于自己的Llama 3 大模型和对话客户端
  • 2411C++,C++26反射示例
  • POI实现根据PPTX模板渲染PPT
  • Scala入门基础(17.1)Set集习题
  • 除了 Postman,还有什么好用的 API 调试工具吗
  • 【VMvare虚拟机-Ubuntu】解决内存不足问题
  • Oracle重做日志文件的添加及删除
  • 15. 数据维度转换 -- torch.reshape
  • 前端实战:使用JS和Canvas实现运算图形验证码(uniapp、微信小程序同样可用)
  • 代码随想录 | Day21 | 二叉树:找树左下角的值路径总和
  • 判断链表的全部n个字符是否中心对称。
  • Dbt基本概念与快速入门
  • office 2021安装教程
  • C - Make Isomorphic题解
  • Java 类和对象-小结(重要)
  • 基于STM32设计的智能货架(华为云IOT)(225)
  • VUE
  • 跨平台集成:在 AI、微服务和 Azure 云之间实现无缝工作流
  • 深入理解算法效率:时间复杂度与空间复杂度
  • Spark_natural_join
  • 828华为云征文 | 华为云Flexusx与Docker技术融合,打造个性化WizNote服务
  • 深入理解中比较两个字符串差异的方法”或“高效比对字符串:diff-match-patch:c++实战指南
  • c++面向对象
  • 栈OJ题——用栈实现队列
  • 嵌入式初学-C语言-数据结构--七