网络知识学习(笔记二)

news2024/9/20 6:06:56

        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.coloradmin.cn/o/1238670.html

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

相关文章

汇编语言学习笔记

汇编语言的不同种类 as86汇编:能产生16位代码的Intel 8086汇编 mov ax, cs //cs→ax,目标操作数在前GNU as汇编:产生32位代码,使用AT&T系统V语法 movl var, %eax // var→%eax,目标操作数在后内嵌汇编…

12、人工智能、机器学习、深度学习的关系

很多年前听一个机器学习的公开课,在Q&A环节,一个同学问了老师一个问题“机器学习和深度学习是什么关系”? 老师先没回答,而是反问了在场的同学,结果问了2-3个,没有人可以回答的很到位,我当时也是初学一脸懵,会场准备的小礼品也没有拿到。 后来老师解释“机器学习和…

dolphinscheduler有任务一直在运行(问题)目前对数据库解决

dolphinscheduler有任务一直在运行(问题)目前对数据库解决 危害: 这么多的任务没有结束,会涉及很多问题的,系统的数据盘会不断入职日志,数据量很大, 其实对于dolphinscheduler的性能是下降的&a…

c语言编程(模考3)统计字符串中数字字符的个数

统计字符串中数字字符的个数 #include<stdio.h> int main(){char inputString[100];int digitCount 0;printf("请输入一个字符串&#xff1a;");scanf("%s",inputString);for(int i0;inputString[i]!\0;i){if (inputString[i]>0&&inpu…

怎样实现内网穿透?

第一步&#xff1a;cpolar是一种安全的内网穿透云服务&#xff0c;它将内网下的本地服务器通过安全隧道暴露至公网。使得公网用户可以正常访问内网服务。打开网址 cpolar 下载 。 步骤&#xff1a; 打开网站>点击免费试用>创建账号>下载应用一直点下一步下载完成。第…

@PropertySource适配通配符加载到Environment的一种方案

PropertySource可将配置文件加载到内存&#xff0c;时间有限说干的&#xff0c;PropertySource注解有4个参数&#xff0c;其中value表示要加载文件的路径&#xff0c;这个参数不支持通配符。还有一个参数PropertySourceFactory是加载配置文件的工厂&#xff0c;这两个参数配合使…

【云原生】初识 Service Mesh

目录 一、什么是Service Mesh 二、微服务发展历程 2.1 微服务架构演进历史 2.1.1 单体架构 2.1.2 SOA阶段 2.1.3 微服务阶段 2.2 微服务治理中的问题 2.2.1 技术栈庞杂 2.2.2 版本升级碎片化 2.2.3 侵入性强 2.2.4 中间件多&#xff0c;学习成本高 2.2.5 服务治理功…

大家为什么开始配置长效IP代理?长效IP代理有什么优势?

随着网络技术的发展&#xff0c;越来越多的人开始关注网络安全和隐私保护。其中&#xff0c;长效IP代理作为一种安全、高效的解决方案&#xff0c;受到了越来越多人的关注。本文将探讨大家为什么开始配置长效IP代理&#xff0c;以及长效IP代理的优势。 一、长效IP代理的优势1.保…

Python Pandas简介及基础教程+实战示例。

文章目录 前言一、Pandas简介二、Python Pandas的使用关于Python技术储备一、Python所有方向的学习路线二、Python基础学习视频三、精品Python学习书籍四、Python工具包项目源码合集①Python工具包②Python实战案例③Python小游戏源码五、面试资料六、Python兼职渠道 前言 Pan…

马蹄集oj赛(双周赛第十五次)

目录 小码哥的开心数字 淘金者 捡麦子 小码哥玩游戏 手机测试 自动浇花机 买月饼 未来战争 双人成行 魔法水晶球 ​编辑自驾游 文章压缩 银河贸易市场 小码哥的开心数字 子难度&#xff1a;青铜 0时间限制&#xff1a;1秒 巴占用内存&#xff1a;64M 小码哥有超能…

HCIP-四、MUX-vlanSuper-vlan+端口安全

四、MUX-vlan&Super-vlan端口安全 MUX-vlan实验拓扑实验需求及解法1. 在SW1/2/3分别创建vlan10 20 30 402. SW1/2/3之间使用trunk链路&#xff0c;仅允许vlan10 20 30 40 通过。3. SW与PC/Server之间使用access链路。4. ping验证&#xff1a; Super-vlan端口安全实验拓扑实…

在矩池云使用安装AgentTuning

AgentTuning 是清华大学和智谱AI共同推出的 AI Agent方案。 AgentTuning可以令LLM具备更强大的泛化能力&#xff0c;而且同时保持其通用语言能力&#xff0c;项目中包含的AgentInstruct 数据集和 AgentLM 模型均已开源。 项目地址&#xff1a;https://github.com/THUDM/Agent…

扩散模型实战(十一):剖析Stable Diffusion Pipeline各个组件

推荐阅读列表&#xff1a; 扩散模型实战&#xff08;一&#xff09;&#xff1a;基本原理介绍 扩散模型实战&#xff08;二&#xff09;&#xff1a;扩散模型的发展 扩散模型实战&#xff08;三&#xff09;&#xff1a;扩散模型的应用 扩散模型实战&#xff08;四&#xff…

算法 全排列的应用

#include <iostream> #include <string>using namespace std;// 交换字符串中两个字符的位置 void swap(char& a, char& b) {char temp a;a b;b temp; }void fun(string str) {string a str.substr(0,4); int aa;sscanf(a.c_str(), "%d",…

如何在windows使用别名远程执行命令

需求背景 在开发中,需要在服务器执行脚本,需要如下几步操作: 1.打开xshell 2.登录服务器 3.进入命令脚本的路径 4.执行脚本 但是,作为懒人来说,操作太繁琐了,真麻烦,能不能一键就解决那么多操作?所以,开始研究windows有没有这个东西,而且不需要额外的软件就可以实现的.结…

IBM ELM—系统工程全生命周期管理平台

产品概述 Engineering Lifecycle Management是IBM提供的工程全生命周期管理组合工具&#xff0c;帮助企业降低开发成本&#xff0c;应对开发挑战并更快地发展其流程和实践。 随着产品变得更加复杂且数字化&#xff0c;传统的工程开发不再能及时且有效地满足系统工程的复杂度&a…

坚鹏:湖北银行数字化转型背景下银行运营管理创新培训圆满结束

湖北银行正式成立于2011年2月27日&#xff0c;总部设在武汉。现有员工5000余人。营业网点从成立之初的93家增长至241家&#xff0c;实现全省17个市州、59个县域营业网点全覆盖。截至2022年末&#xff0c;全行资产总额4026亿元&#xff0c;存款总额2956亿元&#xff0c;贷款总额…

【干货】Ehome demo工具的详细使用方法

关注小编的都知道&#xff0c;除了日常方案与各类技术难题&#xff0c;小编也会经常分享一些技术干货。今天小编就给大家介绍一下Ehome demo工具的详细使用方法。利用该工具可以测试和调试海康监控设备。 具体步骤如下&#xff1a; 1、选择所需IP&#xff1b; 2、如果是测试本…

echarts 几千条分钟级别在小时级别图标上展示

需求背景解决效果ISQQW代码地址strategyChart.vue 需求背景 需要实现 秒级数据几千条在图表上显示&#xff0c;(以下是 设计图表上是按小时界别显示数据&#xff0c;后端接口为分钟级别数据) 解决效果 ISQQW代码地址 链接 strategyChart.vue <!--/** * author: liuk *…