网络(三) 协议

目录

1. IP协议;

2. 以太网协议;

3. DNS协议, ICMP协议, NAT技术.


1. IP协议:

1.1 介绍:

        网际互连协议, 网络层是进行数据真正传输的一层, 进行数据从一个主机传输到另一个主机. 网络层可以将数据主机进行传送, 那么传输层保证数据可靠性, 一起就是TCP/IP协议.

路径选择: 确认目的主机之后, 就要找到最短路径将数据给主机. 这里是不是和图数据结构很类似, 找到最短路径. 找寻的时候和路由器来确认目的主机的位置.

主机和路由器: 主机配有IP地址,但是不进行路由控制的设备. 路由器: 既配有IP地址,又能进行路由控制.

 1.2 IP协议格式:

版本号: IP协议的版本; 首部长度: 报文长度, 总长度: 报头+有效载荷.

16位标识: 唯一的标识主机发送的报文,如果数据在IP层进行了分片,那么每一个分片对应的id都是相同的。

3位标志位段: 第一位: 保留, 第二位: 禁止分片, 第三位: 更多分片.

13位片偏移:分片相对于原始数据开始处的偏移.

8位协议: 协议类型;

16位首部检验和:使用CRC进行校验,来鉴别数据报的首部是否损坏,但不检验数据部分。

socket里需要IP和port就是给网络层ip使用, 进行路由转接工作的. 端口号是给tcp和udp使用的.

 1.3 分片和组装:

        数据链路层解决问题, MTU: IP交给MAC帧的报文不能超过某个值,这个值就叫做最大传输单元, 一般是1500字节. 如果超过1500字节就需要进行分片, 再交给mac帧进行传输.

到达对端网络层就需要先组装再进行给传输层传送.

一般是不会进行分片的, 会增加丢包的概率, 数据在路由器中也可能进行分片, 

数据的分片和组装完全是由IP协议自己完成的,传输层和链路层不必关心也不需要关心。

如果一个数据包是4500字节, 那么就是采用分片, 分成4个数据片进行发送. 到达对端主机后还有16位标识, 标识一个分片完的数据是一个ip协议出去的. 3位标志和13位片偏移标识分片组合需要的偏移量(离第一个片段的位置),  1480 / 8 = 185.

组装的过程:

        IP报头里面有源ip地址, 可以区分不同主机的数据, 16位标识表示来自哪个数据分片进行分片出来的.通过这两个就可以把数据进行组装. 

第一个分片的片偏移一定是0, 最后一个分片报文的标志位一定是0, 以及片偏移是按照字节数/ 8进行的, 按照以上规则在进行组装.

分片丢包:

        如果第一个分片报文丢了, 那么接收不到片偏移为0的报文, 最后一个分片报文丢了标志位为0的就找不到, 以及其他丢了就找不到片偏移为特殊值的报文.

为啥不建议分片?

        因为数据必须进行组装全部之后才可以确认接收到了, 会大大降低传输效率, 增加丢包可能性的, 而且进行数据重传只能全部传递. 最好是一次交给ip协议的报文不要太大, 在1460字节之内(除去报文长度), 

 1.4 网段划分:

        IP地址是由网络号和主机号组成的, 网络号: 保证相连的两个网段具有不同的标识,

主机号: 同一个网络中, 拥有同一个网络号, 但是主机号一定不一样.

找主机, 先查找对应的网段号, 然后进对应网段, 查找对应的主机号,

 1.5 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。

计算方式: 2^7 = 128为A类地址, 2^16 = 65536个就是B类; C类就是16,842,752个.

那么必定会有大量的IP被浪费就使用到子网掩码,  IP地址和子网掩码进行按位与就可以的得到网络号. 对应就是和255.255.255.0进行按位与. 

特殊IP地址:
        全0就是该子网的网络号, 全1就是该子网的广播地址, 127.*就是本地回环地址.

本地环回原理: 其实是数据贯穿网络协议栈, 但是不会到网络中以及网卡中.自顶向下进行解包和封装一次, 来测试本地释放正常. 首先会放在IP输入队列中然后判断是否为本地IP和广播IP, 

不是就向下交付, 是的话就进行重新放到输入IP队列中.

IP地址不够

        2^32就是大概就是43亿个IP地址, 但是远远不够, 可以使用子网划分以外还可以使用IPV6, 2^64就有数非常大的. 其次使用NAT技术(不同子网存在相同的主机号), 后面具体说. 

私网IP和公网IP:

        私网IP: 不连接到网络中,  公网IP是可以访问到网络的.

数据是如何发送到服务器的?

        LAN口: 连接本地的网络接口, WAN口: 连接互联网的网络接口.

 为什么私网IP不能出现在公网当中

        因为私网IP无法标识主机的唯一性, 而且私网IP可以解决IP地址不足的问题, 但是一个网络中的主机无法标识. 

 1.6 路由:

        路由器在查找目的ip的时候进行一跳跳的就是源mac地址到目的mac地址的过程.

路由器在查找路由表时候就给出下一跳到哪里去. route指令就可以进行查询.

相对应还有路由表生成算法.

 2. 以太网协议:

2.1 介绍:

        是数据链路层协议, 将数据转到到下一跳主机实际是属于局域网通信范畴的,而这实际就是链路层需要解决的问题. 

以太网: 最普遍的一种局域网技术.

令牌环网无线LAN/WAN, 虽然采用的局域网技术不一样, 但是在网络协议栈中屏蔽底层差异, 发送的时候进行封装对应的局域网技术报头, 然后在向上交付时候去掉报头加上其他局域网报头, 然后再根据网络协议栈进行向上进行交付.

 2.2 以太网原理:

        以太网不是一种具体的网络而是一种技术标志, 数据链路层还包含了物理层的内容, 必须使用双绞线, 以及网络的拓扑结构.

令牌环网络:

        逻辑上是环形拓扑结构, 可以避免数据碰撞, 因为只有拿到令牌的主机才可以发送数据.

 2.3 以太网协议的格式:

        类型只有IP协议, ARP协议和RARP协议, CRC是校验和. 

例子:  主机A找到主机B, 帧协议的类型为0800.

如果主机A收到MAC帧之后就会进行CRC校验, 失败找到发送数据碰撞, 然后就重新发送.

如果主机B收到mac帧之后进行crc验证, 发现mac帧和主机一样就会向上进行交付.

在局域网中收到其他收到mac帧之后进行crc验证不对就丢弃了.

 2.4 MAC地址和MTU:

        MAC地址: 出厂就设置好啦, 无法修改, 具有唯一性.

        MTU: 最大传输单位, 标识数据链路层一次最多发送的数据. 一般是1500字节, 超过就要在ip层进行分片, 然后就是MAC最少数据就是46字节.

 2.5 MTU的影响:

(1) 对IP协议的影响:

        会导致如果大于1500字节就会进行分片, 然后到达对端主机就会进行组装. 

(2) 对UDP协议的影响:

        因为IP报文和udp报文一起是20+8 = 28; 那么超过1500-28 = 1472字节就会进行分片. 会增加udp报文丢失的概率.

(3) 对TCP的影响:

        增加TCP丢包的概率, 一般降低重传的次数, 会MSS和MTU的最小值进行设置传送大小.

 2.6 ARP协议:

(1) 认识:

        由IP地址推出MAC地址,  因为在局域网的路由器找到主机就需要mac帧.

(2) ARP协议格式:

        路由器先构建ARP协议请求, op置为1(arp请求), 2是arp应答. 硬件类型字段设置为1, 因为是以太网协议, 协议类型设置为0800,因为路由器是要根据主机B的IP地址来获取主机B的MAC地址, 硬件地址长度和协议地址长度分别设置为6和4,因为MAC地址的长度是48位,IP地址的长度是32位。发送端以太网地址和发送端IP地址,对应就是路由器D的MAC地址和IP地址, 因此将目的以太网地址的二进制序列设置为全1,表示在局域网中进行广播.

arp请求:

arp应答:

arp向下还要包装成mac帧才可以进行发送.

(3) RARP协议:

        通过MAC地址找到IP地址.

3. DNS协议:

        DNS: 域名系统, 将域名转化成IP地址的应用层协议.  一级域名: .com .net .org .eng等;

二级域名: 一般是公司名. 

DNS协议的原理:
        在浏览器中输入url, 然后进行域名解析,  首先会在浏览器的DNS缓存查询对应域名, 有就完成解析; 没有到操作系统中的DNS缓存, 还是没有就到本地的hosts文件, 一直到下层进行查询.

 3.2 ICMP协议:

        Internet控制报文协议, ICMP协议是属于IP协议的上层协议.

作用:

        确认IP包是否成功到达目标地址, 通知在发送过程中IP包丢弃的原因. 例如主机B关机了, 

很久主机A得不到响应, 就是使用ICMP协议来看看是啥原因.

 3.3 NAT技术:

        网络地址转换技术, 解决IP地址不足的主要手段,并且能够有效地避免来自网络外部的攻击,隐藏并保护网络内部的计算机. 在局域网中将全局IP转化成私有IP, 路由器的话就相反. 

造成一种局域网中相同IP的私有IP不会冲突, 出了局域网就改变公网IP即可. 其中使用NATP来进行公网IP和私网IP的转换.

NAT技术也有缺点: 就是无法从NAT外部向内部服务器建立连接,因为外部无法知道内部的私网IP,也就无法主动与内部服务器建立连接。转换表的生成和销毁都需要额外开销。通信过程中一旦NAT设备异常,即使存在热备,所有的TCP连接也都会断开。

 3.4 正反向代理:

        正向代理: 客户端和服务器之间的代理服务器, 客户端访问代理服务器, 由代理服务器去访问服务器. 可以加快访问资源, 如果大量访问同一个资源就放在代理服务器中就无需总是访问外网.

        反向代理: 对于客户端而言,反向代理服务器就相当于目标服务器,用户不需要知道目标服务器的地址,用户只需要访问反向代理服务器就可以获得目标服务器提供的服务. 可以起到负载均衡的作用. 

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

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

相关文章

用Python绘制一只懒羊羊

目录 一、准备工作 二、Turtle库简介 三、绘制懒羊羊的步骤 1. 导入Turtle库并设置画布 2. 绘制头部 3. 绘制眼睛 4. 绘制嘴巴 5. 绘制身体 6. 绘制四肢 7. 完成绘制 五、运行代码与结果展示 六、总结 在这个趣味盎然的技术实践中,我们将使用Python和Turtle图形…

【C语言】预处理详解

他们想要逃避工作的压迫,却又被功绩社会深植的价值观绑架。 预定义符号 1. C语言设置了⼀些预定义符号,可以直接使用,预定义符号也是在预处理期间处理的。 1 __FILE__ //进⾏编译的源⽂件 2 __LINE__ //⽂件当前的⾏号 3 __DATE__ //⽂件被编…

探秘差分数组:算法星河中闪耀的区间掌控之星

本篇鸡汤:夜深人静,正是你追梦的时刻。熬过这段孤独,未来会因你而闪亮! 探索新知,点亮智慧!关注我,一起成长,点赞收藏不迷路! 欢迎拜访&…

Ubuntu环境 nginx 源码 编译安装

ubuntu 终端 使用 wget 下载源码 sudo wget http://nginx.org/download/nginx-1.24.0.tar.gz解压刚下载的源码压缩包 nginx-1.24.0.tar.gz sudo tar -zxvf nginx-1.24.0.tar.gz 解压完成 产生 nginx-1.24.0 目录 进入该目录 cd ./nginx-1.24.0 目录下有一个可执行文件 con…

linux如何修改密码,要在CentOS 7系统中修改密码

要在CentOS 7系统中修改密码,你可以按照以下步骤操作: 步骤 1: 登录到系统 在登录提示符 localhost login: 后输入你的用户名。输入密码并按回车键。 步骤 2: 修改密码 登录后,使用 passwd 命令来修改密码: passwd 系统会提…

C# volatile 使用详解

总目录 前言 在多线程编程中,确保线程之间的正确同步和可见性是一个关键挑战。C# 提供了多种机制来处理这些挑战,其中之一就是 volatile 关键字。它用于指示编译器和运行时环境不要对特定变量进行某些优化,以保证该变量的读写操作是线程安全…

[Unity 热更方案] 使用Addressable进行打包管理, 使用AssetBundle进行包的加载管理.70%跟练

在正常的开发过程中我们经常遇到一些关于热更的方案,有一些已有的方案供我们选择,但是实机情况往往不尽如人意,各有优缺点. 现在我们同样有一个热更的需求,但是要求打包简单,加载过程可查,防止出现一些资源和流程的问题. 下面介绍我在项目中使用的方案. 打包方面使用Addressabl…

Flink运行时架构

一、系统架构 1)作业管理器(JobManager) JobManager是一个Flink集群中任务管理和调度的核心,是控制应用执行的主进程。也就是说,每个应用都应该被唯一的JobManager所控制执行。 JobManger又包含3个不同的组件。 &am…

在 Windows 11 中为 SMB 3.x 文件共享协议提供 RDMA 支持

注:机翻,未校。 Enable SMB Direct in Windows 11 在 Windows 11 中启用 SMB Direct Provides RDMA support for the SMB 3.x file sharing protocol 为 SMB 3.x 文件共享协议提供 RDMA 支持 Vigneshwaran Vijayakumar November 3, 2024 Last Updat…

用AI生成PPT,办公效率提升新方式

用AI生成PPT,办公效率提升新方式!在快节奏的时代,如何优雅应对高效办公的挑战? 或许你也有这样的经历:开会前临时被要求制作PPT,一阵头大,却只能硬着头皮上。科技的发展为我们带来了更智能的解…

单片机-STM32 IIC通信(OLED屏幕)(十一)

一、屏幕的分类 1、LED屏幕: 由无数个发光的LED灯珠按照一定的顺序排列而成,当需要显示内容的时候,点亮相关的LED灯即可,市场占有率很高,主要是用于户外,广告屏幕,成本低。 LED屏是一种用发光…

ASP.NET Core 6.0 如何处理丢失的 Startup.cs 文件

介绍 .NET 6.0 已经发布,ASP.NET Core 6.0 也已发布。其中有不少变化让很多人感到困惑。例如,“谁动了我的奶酪”,它在哪里Startup.cs?在这篇文章中,我将深入研究这个问题,看看它移动到了哪里以及其他变化。…

【嵌入式开发】stm32 st-link 烧录

使用 ST-Link 烧录 STM32 的程序可以通过多种工具实现,例如 STM32CubeProgrammer、Keil、IAR、以及 OpenOCD。以下是通用的步骤说明: 准备工作 硬件准备 确保 ST-Link 调试器与 STM32 芯片引脚正确连接: SWDIO (SWD 数据线) 接至 STM32 的 SW…

仿 RabbitMQ 的消息队列3(实战项目)

七. 消息存储设计 上一篇博客已经将消息统计文件的读写代码实现了,下一步我们将实现创建队列文件和目录。 实现创建队列文件和目录 初始化 0\t0 这样的初始值. //创建队列对应的文件和目录:public void createQueueFile(String queueName) throws IO…

【STM32HAL-----GPIO】

1. 什么是GPIO?(了解) 2. STM32 GPIO简介 2.1. GPIO特点 2.2. GPIO电气特性 2.3. GPIO引脚分布图 IO引脚分布特点:按组存在、组数视芯片而定、每组最多16个IO引脚。 3. IO端口基本结构介绍 4. GPIO八种工作模式 4.1. 输入浮空 特…

Midjourney基础-常用修饰词+权重的用法大全

用好修饰词很关键 Midjourney要用除了掌握好提示词的写法,按照上一篇《做Midjourney最好图文教程-提示词公式以及高级参数讲解》画面主体 场景氛围 主体行为 构图方式 艺术风格 图像质量。 要画出有质感的内容我们必须要掌握好“修饰词”,这些修饰…

二叉树和堆

树概念及结构(了解) 树的概念(看看就行) 树是一种 非线性 的数据结构,它是由 n ( n>0 )个有限结点组成一个具有层次关系的集合。 把它叫做树是因 为它看起来像一棵倒挂的树,也就是…

C语言 指针_野指针 指针运算

野指针: 概念:野指针就是指针指向的位置是不可知的(随机的、不正确的、没有明确限制的) 指针非法访问: int main() {int* p;//p没有初始化,就意味着没有明确的指向//一个局部变量不初始化,放…

腾讯 Hunyuan3D-2: 高分辨率3D 资产生成

腾讯 Hunyuan3D-2:高分辨率 3D 资产生成的突破 前言 在当今数字化时代,3D 资产生成技术正变得越来越重要。无论是游戏开发、影视制作还是虚拟现实领域,高质量的 3D 模型和纹理都是创造沉浸式体验的关键。然而,传统的 3D 资产制作…

Java如何实现反转义

Java如何实现反转义 前提 最近做的一个需求,是热搜词增加换一批的功能。功能做完自测后,交给了测试伙伴,但是测试第二天后就提了一个bug,出现了未知词 levis。第一眼看着像公司售卖的一个品牌-李维斯。然后再扒前人写的代码&…