网络知识学习(笔记二)

        ios模型规定的网络模型一共有7层,但是实际使用过程中,4层的TCP/IP模型是经常使用的,网络知识学习笔记里面也是基于4层TCP/IP模型进行分析的,前面已经讲了:(1)物理层,(2)数据链路层。本次笔记将记录网络层、运输层的UDP,运输层的TCP将放在下次笔记中记录。

一、网络层

        网络层主要是:IP、ICMP、ARP协议等。

        (1)如下图所示,网络层的报文主要有两部分组成:首部、数据。

        (2)首部:网络层添加的报文。

        (3)数据:上一层“运输层”传过来的数据报文。

1.1、网络层报文

(1)网络层报文一些长度的规定

        1、网络层数据包报文中,首部得固定长度是20个字节,首部得可变长度部分尾40个字节,总长度为20~60个字节

        2、网络层数据包报文得总长度为65535个字节,是指:首部长度+数据长度

        3、数据链路层中报文要求网络层传过来的数据长度不能超过1500个字节。如果网络层传过来的数据超过了1500个字节,将对网络层中的报文进行分片,每片都是含有网络层的报文首部的。

(2)网络层数据报文首部分析

        网络层报文的格式如下所示,下面将针对报文中的每个部分的内容进行解释。下图所示的占的多少,并不是字节,一个字节有8位。

   

1.版本(Version):占4位

      0100:IPV4

      0110:IPV6

2.首部长度(Header Length):

        占4位二进制乘以4才是最终长度

        最小值:0101,对应的十进制值是5,所以最终首部长度最小是5*4=20字节

        最大值:1111,对应的十进制值是15,所以最终首部长度最大时15*4=60字节

        由于首部固定长度是20字节,所以可变长度是0~40字节

3.总长度:Total Length

        占16位

        3.1.首部+数据部分的长度之和,即整个数据包的长度,最大值是65535字节

        3.2.整个数据包是要传给数据链路层作为帧的数据部分的,但是帧的数据部分不能超过1500字节,所以过大的IP数据包,会被分成片(fragments)传输给数据链路层。

        而且每一片fragments都有自己的网络层首部(IP首部)。

4.区分服务:Differentiated Services Field

        4.1.占8位,可以用来提高网络的服务质量,Quality of Service

        4.2.没有值时:0x00;如果值是0x40,可能路由器就会优先传输这个给IP包,即提高网络服务质量。

        区分服务这部分是不需要用户关心的。

5.标识(Identification):

        5.1.占16位,数据包的ID当数据包传给数据链路层时,发现数据包过大,数据包就会进行分片。每一片fragments都有自己的IP首部,而且这些片的IP首部的标识部分都一样。这样就能区分哪些片是一个IP包拆分的。被分片的数据包的标识位ID是不变的,所有片的标识都是一样的。

        5.2.数据包的ID:代表是哪个IP包。而且有一个计数器专门管理数据包的ID,没发出一个数据包,ID就加1。

        5.3.这个时候虽然能确定下来片fragments属于哪个数据包,但是怎么确定哪个片属于数据包的哪个部分呢?使用下面介绍的片偏移的方式。

        如果数据包过大,标识的数值加到最大的时候,就会变成0,从0从新开始加。

6.片偏移(Fragment Offset)

       同一个数据包的标识ID是一样的,那么划分的长度都是最长的,所以可以通过片偏移的方式,从一个片的位置找到下一个片的位置。

         1.占13位,片偏移乘以8:字节偏移,每一片的长度一定是8的整数倍。

        2.字节偏移:

                        第一片:从IP数据包首部后的第0字节处开始算,共1400字节

                        第二片:从IP数据包首部后的第1400字节处开始算,共1400字节。

                        第三片:从IP数据包首部后的第2800字节处开始算,共1000字节。

                                        所以第一片的字节偏移是0,其IP首部中片偏移就是0/8=0

                        第二片的字节偏移是1400,其IP首部中片偏移就是1400/8=175

                        第三片的字节偏移是2800,其IP首部中片偏移就是2800/8=350

        3.为什么不直接用字节偏移呢,而是要再除以8,用片偏移呢?

                       因为存放偏移量的这部分一共才13位,最大值是8192-1=8191。而整个IP数据包的最大长度是65535字节。所以如果用字节偏移量的话,很可能13位不够表示。

7.标志(Flags)

        1.占3位,每一位有不同的含义。

        2.第一位(Reserved Bit):保留位

        3.第二位(Don't Fragment):1代表不允许分片,0代表允许分片

        4.第三位(More Fragments):1代表不是最后一片,0代表最后一片。

                一旦发现第三位是0,说明这个网络层的数据包已经组装好了。

8.协议和首部检验和

        只对网络协议报文中的首部进行检验。刚开始首部检验和的几位全是零,对首部计算之后的检验值放在首部检验和的位置。

        网络层的数据是从运输层传下来的,那么运输层用的什么协议会被记录下来,放在网络层首部的协议位置处。

        另外,ICMP也有协议字段,但是这些协议是被划分到网络层的。

        传输层的TCP协议的数据,或者UDP协议的数据,都会传输给网络层,被打包成IP协议的数据。

9.生存时间:Time To Live, TTL

        占8位

        1.每个路由器在转发之前都会将TTL减1一旦发现TTL减为0路由器会返回错误报告

        2.各个操作系统的发送数据的默认TTL,减一的次数也是不一样的

        如果没有上面的生存时间,如果用户配置错误,导致数据在两个路由器之间来回的传输出数据,就会占据路由器,导致路由器无法工作。

        所以百度服务器应该是部署在linux服务器上,所以中间经历了64-52=12个服务器。

        3.ping baidu.com -i 1

        设置ping的数据的TTL是1,那么经过第一个路由器时就会减成0,就不会往下再发送包,而是返回报错信息。

        我得ip:192.168.43.143。所以我的第一个网关地址就是192.168.43.1:

二、传输层协议

        1.传输层的TCP协议的数据,或者UDP协议的数据,都会传输给网络层,被打包成IP(IPV4、IPV6)协议的数据。

        2.传输层主要有两个协议:

        1.TCP(Transimission Control Proticol),传输控制协议

如果之前的数据没有发送成功,还会再发送一次,那么就打乱了实时性(现在接收的信息,突然插入一个之前的信息)。

        2.UDP(User Datagram Protocol),用户数据报协议。

如果之前的数据没有成功发过来,那我也不要了,我只关注当前的信息:音视频通话。

        3.两个协议的大致区别:

        4.我们一般发送一个请求,是先在应用层用一个协议封装一个数据,然后在发给下一层,即传输层。

        TCP协议一般封装的是,来自应用层的HTTP/HTTPS等协议封装的数据

        UDP协议一般封装的是,来自应用层的DNS协议封装的数据。

1、UDP协议

1.1、UDP的数据格式

        1.UDP是无连接的,减少了建立和释放连接的开销

        2.UDP尽最大可能交付传输的数据,但是不保证数据的完整性,即不保证可靠交付。

        3.因此不需要维护一些复杂的参数,首部只有8个字节。(TCP首部至少20个字节)

1.2、UDP首部的构成

        1.UDP长度

                16位,2字节:表示  首部的长度+数据的长度

        2.UDP校验和 Checksum

                检验和的计算部分:伪首部+首部+数据

                伪首部:仅在计算检验和时起作用,并不会传递给网络层。

        3.端口Port

                1.服务器可以在一个端口上开启一个服务器软件,这个服务器软件来监听发送到这个端口的数据。之后服务器软件再从8080端口将数据返回给客户端。

                2.UDP首部中每个端口部分占用2字节,可以推测出端口号的取值范围0~65535。

                3.客户端的源端口是应用软件发送请求时的端口,而且是临时开启的随机端口,不固定。

                临时开一个端口发数据,所以同一个应用软件前后两次发数据时,源端口很可能是不一样的。

                4.服务响应请求,返回数据时。此时UDP数据包首部中的目的端口部分,就是客户端发送这个数据的源端口。

                客户端接收到响应的数据,发现目的端口是12656,就会恍然;原来是响应我上次从12656端口发送的数据。

                服务器发送数据时,源端口不变。

        5.防火墙可以设置开启/关闭一些端口来提高安全性。

        6、防火墙和服务器之间的管理

        用户只能发请求过来,请求获得服务器数据,不能通过账号或密码直接访问服务器。

1.3、UDP的抓包分析

        注意:服务器是采用80端口监听数据的。

下面是抓包分析UDP报文数据格式。

        1.传输层的首部是1f 40 0f a8 00 3f 0e 73这8个字节,下面的部分02开始是传输层的数据部分。

        2.传输层的数据会传给网络层,被封装成包:而且数据部分是从1f 40 0f a8 00 3f 0e 73这8个字节开始。

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

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

相关文章

Linux系统管理与服务器安全:构建稳健云数据中心

💂 个人网站:【 海拥】【神级代码资源网站】【办公神器】🤟 基于Web端打造的:👉轻量化工具创作平台💅 想寻找共同学习交流的小伙伴,请点击【全栈技术交流群】 在当今数字化时代,云数据中心已经成…

FeignClient相关调用逻辑

https://www.cnblogs.com/chiangchou/p/feign.html#_label3_2

最受欢迎的猫罐头有那些?精选的5款热门猫罐头推荐!

新手养猫很容易陷入疯狂购买的模式,但有些品牌真的不能乱买!现在的大环境不太好,我们需要学会控制自己的消费欲望,把钱花在刀刃上!现在宠物市场真的很内卷,很多品牌都在比拼产品的数据和营养成分。很多铲屎…

物联网AI MicroPython学习之语法 WDT看门狗外设

学物联网,来万物简单IoT物联网!! WDT 介绍 模块功能: 看门狗WDT(WatchDog Timer)外设驱动模块 接口说明 WDT - 构建WDT对象 函数原型:WDT(timeout)参数说明: 参数类型必选参数&#xff1f…

12-25v转3.3v高清水下钓鱼摄像头电源供电芯片方案

高清水下钓鱼摄像头电源芯片方案:12-25V转3.3V,支持超宽电压输入范围和30米长线视频放大 在水下钓鱼摄像头设计中,为了实现高清画质和稳定的电源供应,需要一款能够将12-25V转换为3.3V输出的高效电源芯片。这款电源芯片不仅支持高…

Java使用x-www-form-urlencoded发请求

平常在开发过程中用的最多的就是JSON格式&#xff0c;请求编码就是 application/json&#xff0c;但偏偏有些接口是 x-www-form-urlencoded&#xff0c;怎么办呢&#xff0c;重新封装喽 在POSTMan工具是叫 x-www-form-urlencoded 在 APIpost工具中是叫 urlencoded Map<Str…

Spring Boot 邮件发送(五种类型的邮件)

邮件协议&#xff1a; SMTP、POP3、IMAP SMTP 协议全称为 Simple Mail Transfer Protocol&#xff0c;译作简单邮件传输协议&#xff0c;它定义了邮件客户端软件与 SMTP 服务器之间&#xff0c;以及 SMTP 服务器与 SMTP 服务器之间的通信规则。 用户先将邮件投递到腾讯的 SMT…

论文阅读 Forecasting at Scale (一)

最近在看时间序列的文章&#xff0c;回顾下经典 论文地址 项目地址 Forecasting at Scale 摘要1、介绍2、时间业务序列的特点3、Prophet预测模型3.1、趋势模型3.1.1、非线性饱和增长3.1.2、具有变化点的线性趋势3.1.3、自动转换点选择3.1.4、趋势预测的不确定性 摘要 预测是一…

暗物质探测器认知教学VR元宇宙平台打破传统束缚

“飞船正在上升&#xff0c;马上就冲出大气层了!”这是一位在1&#xff1a;1还原的神舟飞船返回舱内借助VR设备置身元宇宙世界&#xff0c;沉浸式体验升空全过程的游客兴奋地说道。不仅如此&#xff0c;在载人飞船训练期&#xff0c;元宇宙技术为航天员虚拟一个逼真的太空世界&…

vue3 iconify 图标几种使用 并加载本地 svg 图标

iconify iconify 与 iconify/vue 使用 下载 pnpm add iconify/vue -D使用 import { Icon } from "iconify/vue";<template><Icon icon"mdi-light:home" style"color: red; font-size: 43px" /><Icon icon"mdi:home-flo…

shell脚本三

目录 一、循环语句 一、循环 二、for循环语句 1.列表循环 2.与c语言循环相似的for循环 3.使用for打印三角形以及乘法表 4.测试172.16.114.0网段存活的主机并将存活的主机IP地址写入文件中&#xff0c;未存活的主机放入另一文件中 三、while循环语句 四、until循环语句…

如何使用 Navicat 连接 GaussDB 主备版

Navicat Premium&#xff08;16.2.8 Windows版或以上&#xff09; 已支持对GaussDB 主备版的管理和开发功能。它不仅具备轻松、便捷的可视化数据查看和编辑功能&#xff0c;还提供强大的高阶功能&#xff08;如模型、结构同步、协同合作、数据迁移等&#xff09;&#xff0c;这…

每日一练:质因数分解

1. 题目 从键盘输入一个整数&#xff0c;开始整数的质因数分解&#xff0c;最后打印出该整数的所有质因数。 2.解题思路 1&#xff09;初始化&#xff1a; 从最小的质数开始&#xff0c;将输入的整数不断除以质数&#xff0c;直到无法整除为止。   2&#xff09;循环&#x…

ansible的基本安装

目录 一、简介 1.ansible自动化运维人工运维时代 2.自动化运维时代 3.ansible介绍 4.ansible特点 二、ansible实践 1.环境 2.ansible管理安装 3.ansible被管理安装 4.管理方式 5.添加被管理机器的ip 6.ssh密码认证方式管理 三、配置免密登录 1.ansible自带的密码…

【grep】从html表格中快速定位某个数据

文章目录 1 背景2 参考知识2.1 grep2.2 HTML基础语言标签 3 解决方案 1 背景 在html中是一堆表格、图片、文字什么的&#xff0c;想从表格中提取关键词为“GJC”后对应的数字&#xff0c;怎么办呢&#xff1f; 逐个打开html文件&#xff0c;“ctrlF”搜一下&#xff0c;然后复…

vue项目中element-ui对话框el-dialog嵌套显示时多了一个遮罩层解决办法

在对话框里又嵌套了一个对话框展示时&#xff0c;多了一个遮罩层&#xff0c;如下图所示&#xff1a; 解决办法如下&#xff1a; 给对话框添加append-to-body 属性&#xff0c;参考以下代码&#xff1a; <el-dialog :visible.sync"dialogVisible" append-to-body …

所有产品都值得用AI再做一遍,让AGI与品牌营销双向奔赴

微软 CEO Satya Nadella 曾经说过&#xff1a;“所有的产品都值得用 AI 重做一遍。” AI 大模型的出现&#xff0c;开启了一个全新的智能化时代&#xff0c;重新定义了人机交互。这让生成式 AI 技术变得「触手可得」&#xff0c;也让各行业看到 AGI 驱动商业增长的更大可能性。…

ui设计师简历自我评价的范文(合集)

ui设计师简历自我评价的范文篇一 本人毕业于艺术设计专业&#xff0c;具有较高的艺术素养&#xff0c;平时注重设计理论知识的积累&#xff0c;并将理论应用到作品中。了解当下设计的流行趋势&#xff0c;设计注重细节、重视用户体验&#xff0c;对色彩搭配有着浓厚的兴趣&…

13、深度学习之神经网络

深度学习是机器学习中重要的一个学科分支,它的特点就在于需要构建多层“深度”的神经网络。 人们在探索人工智能初期,就曾设想构建一个用数学方式来表达的模型,它可以模拟人的大脑,大脑我们都知道,有很多神经元,每个神经元之间通过突触链接。 神经网络的设计就是模仿了这…

11.6AOP

一.AOP是什么 是面向切面编程,是对某一类事情的集中处理. 二.解决的问题 三.AOP的组成 四.实现步骤 1.添加依赖(版本要对应): maven仓库链接 2.添加两个注解 3.定义切点 4.通知 5.环绕通知 五.excution表达式 六.AOP原理 1.建立在动态代理的基础上,对方法级别的拦截. 2. …