【JavaEE】IP协议 应用层协议

news2024/9/27 15:17:17

 🔥个人主页: 中草药

🔥专栏:【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.coloradmin.cn/o/2137691.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Word中插入当前日期与时间

Word中插入当前日期与时间 通过构建基块的方法快速插入当前日期与时间 快捷键操作 快捷键具体功能说明 Alt Shift D 插入当前日期date Alt Shift T 插如当前时间time Ctrl Shift F9 使得域文本变为正常文本 Ctrl F11 锁定域更新域菜单工具会变为黑色 C…

音视频入门基础:AAC专题(5)——FFmpeg源码中,判断某文件是否为AAC裸流文件的实现

一、引言 通过FFmpeg命令: ./ffmpeg -i XXX.aac 可以判断出某个文件是否为AAC裸流文件: 所以FFmpeg是怎样判断出某个文件是否为AAC裸流文件呢?它内部其实是通过adts_aac_probe函数来判断的。从《FFmpeg源码:av_probe_input_for…

Qt/C++ 了解NTFS文件系统,获取首张MFT表数据,解析文件记录头内容找到第一个属性偏移地址

系列文章目录 一、Qt/C 了解NTFS文件系统,了解MFT(Master File Table)主文件表(一) 二、Qt/C 了解NTFS文件系统,解析盘符引导扇区数据获取MFT(Master File Table)主文件表偏移地址 三、Qt/C 了解NTFS文件系统,获取首张…

还在为企微联系人烦恼?一招解决!企业微信2024年效率升级全攻略

现在信息多得让人眼花,微信里头那些企业微信的联系人是不是让你头疼? 看着满屏的绿色头像,心里想:“我就想和朋友聊聊天,怎么就这么难?”别急,今天教你个办法,轻松搞定这些小烦恼&am…

【无标题】达瓦达瓦

📢博客主页:https://blog.csdn.net/2301_779549673 📢欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正! 📢本文由 JohnKi 原创,首发于 CSDN🙉 📢未来很长&#…

胤娲科技:解锁AI奥秘——产品经理的智能进化之旅

当AI不再是遥不可及的科幻 想象一下,你走进一家未来感十足的咖啡厅,无需言语,智能咖啡机就能根据你的偏好调制出一杯完美的拿铁; 打开手机,AI助手不仅提醒你今天有雨,还贴心推荐了最适合雨中漫步的音乐列表…

C语言中的GCC的优化和数组的存放方式、Cache机制、访问局部性

“我们仍需共生命的慷慨与繁华相爱,即使岁月以刻薄和荒芜相欺” 文章目录 前言文章有误敬请斧正 不胜感恩!第一题:***什么是gcc:***C 语言中,“gcc -O2”是使用 GCC 编译器时的一个编译选项。第一部分:为什…

利用yolov8模型实现的西红柿成熟程度检测系统包含源码+配置说明(基于YOLOv8的西红柿成熟程度检测系统)

西红柿成熟程度的检测对于农业生产尤为重要,可以提高收获效率和产品质量。本项目利用YOLOv8(You Only Look Once v8)模型实现了一个高效的西红柿成熟程度检测系统。该系统可以自动识别西红柿的颜色,从而判断其成熟程度。 关键特性…

pycharm从VCS获取项目报错unable to access:Recv failure:Connection was reset

(已老实求放过) 版本:PyCharm Community Edition 2024.2.1 【解决办法】取消Git的网络代理,在目标路径所在文件夹处右键选择Git Bash Here,输入以下命令: git config --global --unset http.proxy git …

2024最新版零基础学习Modbus通信协议(保姆级教程)

合集 - 上位机开发(2) 1.零基础学习Modbus通信协议09-13 2.RS485与ModbusRTU09-10 收起 大家好!我是付工。 2012年开始接触Modbus协议,至今已经有10多年了,从开始的懵懂,到后来的顿悟,再到现在的开悟,…

STM32的寄存器深度解析

目录 一、STM32 寄存器概述 二、寄存器的定义与作用 三、寄存器分类 1.内核寄存器 2.外设寄存器 四、重要寄存器详解 1.GPIO 相关寄存器 2.定时器相关寄存器 3.中断相关寄存器 4.RCC 相关寄存器 五、寄存器操作方法 1.直接操作寄存器 2.使用库函数操作寄存器 六…

4个方法教你图片转PDF怎么弄。

我们有时候会接触了一些重要的图片文件或者资料,想要装换成可编辑的PDF格式,更方便自己管理。这时候就会需要转换的工具,我这里就有4款可以完成这种转换的高效工具可以分享给大家。 1、365PDF转换软件 直通车:www.pdf…

软件设计之JavaWeb(3)

软件设计之JavaWeb(3) 此篇应在MySQL之后进行学习: 路线图推荐: 【Java学习路线-极速版】【Java架构师技术图谱】 尚硅谷全新JavaWeb教程,企业主流javaweb技术栈 资料可以去尚硅谷官网免费领取 此章节最好学完JDBC观看 学习内容: 请求转发…

jenkins流水线+k8s部署springcloud微服务架构项目

文章目录 1.k8s安装2.jenkins安装3.k8s重要知识1.简介2.核心概念3.重要命令1.查看集群消息2.命名空间3.资源创建/更新4.资源查看5.描述某个资源的详细信息6.资源编辑7.资源删除8.资源重启9.查看资源日志10.资源标签 4.k8s控制台1.登录2.界面基本操作1.选择命名空间2.查看命名空…

损耗金属件检测系统源码分享

损耗金属件检测检测系统源码分享 [一条龙教学YOLOV8标注好的数据集一键训练_70全套改进创新点发刊_Web前端展示] 1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 项目来源AACV Association for the Advancement of Computer V…

全球和局部精细化:提升大模型推理能力的新方法

人工智能咨询培训老师叶梓 转载标明出处 尽管大模型在数学、科学或编程任务上表现出优异的推理精细化能力,但它们在没有外部反馈的情况下,很难识别何时何地需要精细化。为了解决这一问题,来自Meta的FAIR团队和佐治亚理工学院的研究者们提出了…

智能营销才是营销的未来

智能营销新纪元:大模型如何为运营与产品经理赋能 在数字化浪潮席卷全球的今天,营销行业正经历着一场前所未有的变革。随着人工智能技术的飞速发展,特别是大模型技术的兴起,为产品经理和运营人员提供了前所未有的工具与视野&#…

雷·达利欧(Ray Dalio)的20条《原则》

达利欧在《原则》(Principles)一书中总结了许多实用的原则。这些原则被广泛认同,并且适用于多种情景。以下是20条核心原则的英语原文以及中文翻译: 1. Embrace reality and deal with it. 翻译: 拥抱现实并应对它。适合场景: 适用…

c++中的继承和多态

目录 Linux中的管道通信 ​编辑派生类的默认成员函数 继承 派生类的构造 隐藏 如何设计一个不能被继承的类 菱形继承 virtual virtual是如何解决的 内存对象模型 继承和组合 继承 组合 多态 概念 多态的构成条件 虚函数的重写 Linux中的管道通信 派生类的默认成…

[数据集][目标检测]俯拍航拍森林火灾检测数据集VOC+YOLO格式6116张2类别

数据集格式:Pascal VOC格式YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数):6116 标注数量(xml文件个数):6116 标注数量(txt文件个数):6116 标注…