Linux网络 | 网络层IP报文解析、认识网段划分与IP地址

        前言:本节内容为网络层。 主要讲解IP协议报文字段以及分离有效载荷。 另外, 本节也会带领友友认识一下IP地址的划分。 那么现在废话不多说, 开始我们的学习吧!!

        ps:本节正式进入网络层喽, 友友们传输层理解了吗?

目录

认识IP协议

IP协议的报头

报头和有效载荷如何分离

四位版本

八位服务类型 

十六位总长度 

32位源IP和32位目的IP

网段划分 

网络号主机号 

子网掩码 

特殊的IP地址 

分析IP地址不足问题

私有IP和公有IP 

 ifconfig查看IP地址


认识IP协议

        之前已经能做到,将数据从上层拷贝到tcp缓冲区当中,这个是应用层要做的事情。然后我们也能在传输层进行传输控制,比如提供可靠性策。但是真正进行传输,真正进行办事的其实是网络层,也就是IP协议。所以,IP协议的本职工作:提供一种能力,将数据跨网络从A主机送到B主机。

        同时,用户也需要这种能力:将数据可靠的跨网络从A主机送到B主机。

        看下面一张图,利用学生学习的例子来理解一下IP的工作:

        我们的信息从一台主机发送到另一台主机,要经过很多路由器,所以就要对这些主机进行标识。对源IP地址和目的IP来标识源主机和目的主机。

        IP地址就类似于唐僧西天取经,有目标城市,有目标地址,还有目标人物。 

         实际上任何一个主机都是在一个子网当中的,假如下面的圆圈就是子网,下面的放框框就是一个一个的路由器。菱形就是子网中一个一个的主机。假如说有一个主机A想要将数据发送到B主机。

        既然要发送,那么就一定要跨越很多的路由器子网。这就是路由器转发。转发的过程中,一定是先到达目标网络(IP地址的构成 = 目标网络 + 目标主机),即目标主机所在的局域网。然后再交给目标主机。

        其实,这个IP地址就类似于学号。我们的学号是不是被精心涉及过的,是不是有类似于:学员编号 + 专业编号 + 班级编号 + 学生序号?这个学号我们可以简化一下:学号 = 学院 + 序号
如下图是学院编号:

        然后每个学院都有自己的编号,比如001, 002等。 所以组合起来,就比如计算机学院的001号学生。所以学号就是111001。

        假如我是计算机的,假如我今天找到了一个钱包, 这个钱包不知道是谁的,只有一个学号,比如说115008。那么我们就去食堂一个一个的问,看看是谁的。这个问的过程,就是查找。 而查找的本质是排除。这个一个一个问本质是线性遍历,效率太低。

        所以我就想到了学生会主席,学生会主席就是管理这个的,所以,我今天就将这个钱包拍了照片,让学生会主席去办事。所以,学生会主席就将钱包拿到一看,是115开头。说明是电气的,所以学生会主席就将钱包拿到了电器那边。让电气的学生会主席将钱包给他们学院的学生。

        这个故事里面,钱包就是数据。 我就是主机A,那个丢钱包的就是主机B。 然后学生会主席就是路由器。主机A将钱包发给计算机的路由器,计算机的路由器将钱包发给电气的路由器。 电气的路由器再把钱包发给主机B。

        为什么这个过程找到目标主机变快了呢。一这是因为主机A把数据给计算机路由器,是把计算机学院里面的所有主机全部淘汰了,一下子就淘汰了一群人。然后计算机路由器是把所有的路由器中的其他路由器淘汰了。直接找到电气路由器。电气路由器又是把电气学院的所有主机都淘汰了一下子找到了主机B。查找的本质是排除,所以这个方法,是淘汰的速度变快了。

        所以,IP = 目标网络 +目标主机。 本质上是为了让定位更加快速。        

IP协议的报头

报头和有效载荷如何分离

        IP协议报头和有效载荷分离的方法就是:固定长度+自描述字段

        这个固定长度就是四位首部长度。 假设四位首部长度的大小是x,那么x*4 = 真实报头。所以如果标准报头是20个字节,那么这个四位首部长度最少就是5。最多是二进制全1,即15。上面的自描述字段其实就是十六位总长度字段(后面讲解)。

        到时候就是IP协议的报头(除去选项)的长度固定20字节。 只拿四位首部长度的部分和十六位总长度的部分。就能将报头和有效载荷进行分离。

四位版本

        对于IPv4来说,就是4位版本。
        随着入网设备的增多,IPv4已经不足了。所以解决方案就有:NAT技术、IPv6。但是从根本上解决问题还是lpv6。只不过IPv6和IPv4是完全不兼容的。所以上面这是IPv4的报文。IPv6是128个比特位。

八位服务类型 

        3位优先级,四位TOS字段。和1位保留字段。四位TOS字段就表示:最小延时、最大吞吐量、最高可靠性、最小成本。 

十六位总长度 

        报文的总长度。这个十六位总长度 + 4位首部长度就叫做自描述字段。UDP和TCP最终都要把数据交给IP层。无论是字节流还是数据报,所有的报文在IP层其实都是一个一个的数据报。所以,所谓的面向字节流的概念,只是TCP层以上的概念,不是IP层的概念。 

32位源IP和32位目的IP

        我们以前连接服务器,我们要使用IP地址和port。 本质上其实就是socket套接字要用到port和IP地址。为什么?

        为什么需要这两个数字,因为这两个数字就能定位我们的目标主机。其中TCP报头里面填充的是port,IP报头里面填充的是IP地址。——这就是为什么要将点分十进制ip转化为四字节。因为IP报头的源IP和目的IP是四个字节。所以当一个IP报文扔到网络里面的时候,真正要支持路由的其实是根据我们的32位目的IP地址来进行路径选择的。

        在我们真正的通信过程之中,中间的路由器是没有TCP层的,只有双方主机是有TCP层的。(可以有,但是不需要,因为路由器只工作在网络层。)

网段划分 

        网段划分我们要分成两个部分进行理解。 这里先认识一下网段划分。 

网络号主机号 

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

        这两个号是什么意思,就类似于学号 = 学院号 + 学生序号。网络号就是当前的局域网的编号,主机号就是代表这台主机在局域网当中的序号。 所以,IP地址由两部分组成,以后拿到IP地址,就将IP作为两部分来看待,网络号 + 主机号。这里我们就要认识下面这几点:

        1、路由器本质也是特定一个子网的主机,也要配置IP地址。
        2、路由器一定至少要连接2个子网,所以路由器也就相当于同时在两个子网。路由器那么就可以配置多个IP,并且一定会有多个IP。至少两个。——这里我们认为路由器有多张网卡就可以了。
        3、路由器一般是一个子网中的第一台设备,一般他的IP地址都是:网络号 + 1。 (大部分都是,但是有特殊情况)
        4、路由器的功能是IP报文的转发,但是并不仅仅如此。一个路由器还有很多功能,其中一个就是:构建子网(局域网)。

        其实不同的子网就是把网络号相同的主机放到一起。
        如果子网中新增一台主机,则这台主机的网络号和这个子网的网络号一致,但是主机号必须不能和子网中的其他主机重复。 

子网掩码 

        IPv4是32位,其实就是2^32 = 42亿+。 ——》所以IP地址就是一种有限的资源。

        因为是有限的资源,那么IP地址就要很好的管理起来。所以IP地址就被分为了网络地址和主机地址。 其实以前有一种分类方法是五类划分法。就是有ABCDE类。

        但是这种划分方式的缺点很快就显现出来了。大部分组织都申请B类网络地址,导致B类地址很快就分配完了。 并且其中这16位主机号根本就用不完,所以就造成了大量的浪费。

         针对这种浪费的情况,就提出了一种新的方案:子网掩码。叫做CIDR。

        子网掩码也是一个32位正整数,通常用一串“0"来结尾。左侧以"1"开始。将IP地址和子网掩码进行“按位与“操作,得到的结果就是网络号。网络号和主机好的划分与这个IP地址是A类、B类还是C类无关。        

        怎么用呢,就比如此时IP地址是140.252.20.68,子网掩码是255.255.255.0。

        那么得到的网络号就是两个进行按位与。 得到140.252.20.0,所以子网的范围就能知道了是140.252.20.0~140.252.20.255。

        其中有两个IP地址不用,.0和.255。意思就是开区间。 140.252.20.0我们叫做网络号,140.252.20.255我们称为广播。

        如果子网掩码是255.255.255240,那么得到的网络号就是140.252.20.64。这个就是网络号,即:140.252.20(十进制).0100 0000(二进制)。那么IP地址的范围就是:140.252.20.11110000~140.25220.0100 1111。所以,子网掩码,可以对IP32位,进行任意的划分。 

特殊的IP地址 

        主机号全零是局域网;全1是广播。 127.0.0.1为本地环回。

分析IP地址不足问题

        CIDR一定程度上缓解了IP地址的不足。 但是并没有增加IP地址的上限。上面谈到的策略是分类+子网掩码。

        所以就有了两种解决IP地址不足的方法:

  •         动态IP地址分配:就是我们的电脑不想上网的时候,电脑是没有IP地址的。 当想要入网的时候,就要先连接家里的路由器,然后路由器就动态分配了一个IP地址(这个是NAT技术, 后面讲解)。
  •         IPv6:真正的提高了上限。但是与IPv4严重不兼容。其实IPv6现在已经做的很好了,但是现在世界上为什么还是很少使用IPV6呢?因为TCP、IP协议栈是在操作系统内部的,意味着如果要将IPV4改编成IPV6,那么就要把世界上所有的终端设备全部切换成IPv6。给全世界上所有的操作系统换成IPV6,这个是不现实的。但是,如果使用IPV6的用户多于使用IPv4的用户时,那么就能改变lpv6的使用格局。我国是IPV6使用的最好的,当年零八年奥运会长内网就是使用的IPV6,要知道,我国的物联网也是非常发达的,一个地区的网络发达程度取决于什么?取决于用户,用户,说到底就是入网设备。以后智能设备一旦发展起来,那么入网设备将会大幅度增加。谁掌握的入网设备范围广,多,谁在网络领域就有话语权。所以,我国一旦将物联网的设备发展起来,什么只能电气,智能家居啥啥,那么哪个国家的入网备能比过中国?没有,而且我们平时是不是看到时那些大型的互联网公司,有些网站下面是不是都写着一个某某某支持IPV6技术,其实就是我国规定的,要让我们国家的所有入网设备全部支持IPV6技术,到时候物联网起来,就能快速更换成IPV6。就迅速拥有了天数的网民。

私有IP和公有IP 

        如果一个组织内部组件局域网,只用于局域网内的通信,而不是直接连接到Internet上面,使用任意的IP地址都可以,但是RFC 1918规定了用于组建局域网的私有IP地址。

  •         前八位是10的,全部都只能用来组建私网。172.16 到172.31,全部都只能用来组建私网。192.168开头,全部都只能用来组建私网。
  •         其余的用来构建公网。

 ifconfig查看IP地址

——————以上就是本节全部内容哦, 如果对友友们有帮助的话可以关注博主, 方便学习更多知识哦!!!     

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/69001.shtml

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

相关文章

SQLGlot:用SQLGlot解析SQL

几十年来,结构化查询语言(SQL)一直是与数据库交互的实际语言。在一段时间内,不同的数据库在支持通用SQL语法的同时演变出了不同的SQL风格,也就是方言。这可能是SQL被广泛采用和流行的原因之一。 SQL解析是解构SQL查询…

【Docker项目实战】使用Docker部署MinIO对象存储(详细教程)

【Docker项目实战】使用Docker部署MinIO对象存储 前言一、 MinIO介绍1.1 MinIO简介1.2 主要特点1.3 主要使用场景二、本次实践规划2.1 本地环境规划2.2 本次实践介绍三、本地环境检查3.1 检查Docker服务状态3.2 检查Docker版本3.3 检查docker compose 版本四、下载MinIO镜像五、…

webrtc编译需要常用环境变量以及相关名词解释

set vs2022_installD:\\vs2022 set GYP_MSVS_OVERRIDE_PATHD:\\vs2022 set GYP_GENERATORSmsvs-ninja,ninja set WINDOWSSDKDIRD:\\Windows Kits\10 set DEPOT_TOOLS_WIN_TOOLCHAIN0 set GYP_MSVS_VERSION2022 这些环境变量是为了编译 WebRTC 时让 GYP/Depot Tools 正确找到 V…

Windows程序设计10:文件指针及目录的创建与删除

文章目录 前言一、文件指针是什么?二、设置文件指针的位置:随机读写,SetFilePointer函数1.函数说明2.函数实例 三、 目录的创建CreateDirectory四、目录的删除RemoveDirectory总结 前言 Windows程序设计10:文件指针及目录的创建与…

线程互斥同步

前言: 简单回顾一下上文所学,上文我们最重要核心的工作就是介绍了我们线程自己的LWP和tid究竟是个什么,总结一句话,就是tid是用户视角下所认为的概念,因为在Linux系统中,从来没有线程这一说法,…

DRM系列七:Drm之CREATE_DUMB

本系列文章基于linux 5.15 DRM驱动的显存由GEM(Graphics execution management)管理。 一、创建流程 创建buf时,user层提供需要buf的width,height以及bpp(bite per pixel),然后调用drmIoctl(fd, DRM_IOCTL_MODE_CREATE_DUMB, &…

我们信仰AI?从神明到人工智能——信任的进化

信任的进化: 信任是我们最宝贵的资产。而现在,它正像黑色星期五促销的廉价平板电视一样,被一点点拆解。在过去,世界很简单:人们相信晚间新闻、那些满是灰尘书籍的教授,或者手持病历、眉头紧锁的医生。而如…

数据分析系列--[11] RapidMiner,K-Means聚类分析(含数据集)

一、数据集 二、导入数据 三、K-Means聚类 数据说明:提供一组数据,含体重、胆固醇、性别。 分析目标:找到这组数据中需要治疗的群体供后续使用。 一、数据集 点击下载数据集 二、导入数据 三、K-Means聚类 Ending, congratulations, youre done.

1-刷力扣问题记录

25.1.19 1.size()和.length()有什么区别 2.result.push_back({nums[i], nums[left], nums[right]});为什么用大括号? 使用大括号 {} 是 C11 引入的 初始化列表 语法,它允许我们在构造或初始化对象时直接传入一组值。大括号的使用在许多情况下都能让代码…

信息学奥赛一本通 2113:【24CSPJ普及组】小木棍(sticks) | 洛谷 P11229 [CSP-J 2024] 小木棍

【题目链接】 ybt 2113:【24CSPJ普及组】小木棍(sticks) 洛谷 P11229 [CSP-J 2024] 小木棍 【题目考点】 1. 思维题,找规律 【解题思路】 解法1:找规律 该题为:求n根木棍组成的无前导0的所有可能的数…

神经网络参数量和运算量的计算- 基于deepspeed库和thop库函数

引言 最近需要对神经网络的参数量和运算量进行统计。找到一个基于deepspeed库函数计算参数量和运算量的例子。而我之前一直用thop库函数来计算。 看到有一篇勘误博文写道使用thops库得到的运算量是MACs (Multiply ACcumulate operations,乘加累积操作次数&#xf…

读书笔记--分布式架构的异步化和缓存技术原理及应用场景

本篇是在上一篇的基础上,主要对分布式应用架构下的异步化机制和缓存技术进行学习,主要记录和思考如下,供大家学习参考。大家知道原来传统的单一WAR应用中,由于所有数据都在同一个数据库中,因此事务问题一般借助数据库事…

postgresql的用户、数据库和表

在 PostgreSQL 中,用户、数据库和表是关系型数据库系统的基本组成部分。理解这些概念对数据库管理和操作至关重要。下面是对这些概念的详细解释: 1. 用户(User) 在 PostgreSQL 中,用户(也称为 角色&#…

360大数据面试题及参考答案

数据清理有哪些方法? 数据清理是指发现并纠正数据文件中可识别的错误,包括检查数据一致性,处理无效值和缺失值等。常见的数据清理方法有以下几种: 去重处理:数据中可能存在重复的记录,这不仅会占用存储空间,还可能影响分析结果。通过对比每条记录的关键属性,若所有关键…

无用知识研究:std::initializer_list的秘密

先说结论,用std::initializer_list初始化vector,内部逻辑是先生成了一个临时数组,进行了拷贝构造,然后用这个数组的起终指针初始化initializer_list。然后再用initializer_list对vector进行初始化,这个动作又触发了拷贝…

代码随想录day27

669. /** lc appleetcode.cn id669 langcpp** [669] 修剪二叉搜索树*/// lc codestart /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullptr) {}…

基于JMX实现消息队列监控

引言 实时监控中间件保障集群的可用性是极其重要的&#xff0c;本篇文章以JAVA语音基于JMX来实现对Kafka消息队列的监控 实现 添加依赖 在 pom.xml 中添加以下依赖&#xff1a; <dependencies><!-- Kafka 客户端依赖 --><dependency><groupId>org…

.Net Core笔记知识点(跨域、缓存)

设置前端跨域配置示例&#xff1a; builder.Services.AddCors(option > {option.AddDefaultPolicy(policy > {policy.WithOrigins(originUrls).AllowAnyMethod().AllowAnyHeader().AllowCredentials();});});var app builder.Build();app.UseCors(); 【客户端缓存】接…

Jupyterlab和notebook修改文件的默认存放路径的方法

文章目录 1.缘由2.操作流程2.1找到默认的路径2.2创建配置文件2.3修改配置文件内容2.4注意事项 1.缘由 我自己使用jupyterlab的时候&#xff0c;打开是在这个浏览器上面打开的&#xff0c;但是这个打开的文件路径显示的是C盘上面路径&#xff0c;所以这个就很麻烦&#xff0c;因…

HarmonyOS:ArkWeb进程

ArkWeb是多进程模型,分为应用进程、Web渲染进程、Web GPU进程、Web孵化进程和Foundation进程。 说明 Web内核没有明确的内存大小申请约束,理论上可以无限大,直到被资源管理释放。 ArkWeb进程模型图 应用进程中Web相关线程(应用唯一) 应用进程为主进程。包含网络线程、Vi…