文章目录

  • TCP
  • UDP
  • IP
  • IPV6
  • IPSec
  • 以太网帧结构
  • 802.1Q以太网帧结构
  • 802.11无线链路帧
  • SSL记录
  • RTP实时传输协议
  • OpenFlow流表
  • 参考

TCP

  1. 源端口号和目的端口号: 用16bit表示所以端口号范围为0~65535,用来标识源主机和目的主机上的进程,用于运输层的多路复用和多路分解
  2. 序号: 用于TCP重发时区分是第一次发送还是重发的TCP段,还可以在一次连接的范围防止重放攻击,不重数可以在很久时间防止重放攻击
  3. 重放攻击: 攻击者拿到加密片段重新发给服务器,比如我们加密了密码,但攻击者仍然可以在不破解我们密码情况下,可以拿我们加密的密码直接去登录我们账号,所以可以在加密的时候把我们的密码和一个不重数拼在一起再加密,所以我们的密码加密版本,每次都会不同
  4. 确认号: 和序号对应,指示发送确认号的一方下一次想接收的数据的序号,即接收方发送的确认号,表示接收方希望发送方下次发送数据的序号为确认号
  5. 首部长度: 4比特,最多可以表示16个单位,每个单位是32比特即4个字节,所以最多可以表示64字节,所以TCP首部最长为64字节,一般如果没有选项字段只有20字节
  6. 标志字段: 每个占1bit,SYN用于建立TCP连接,FIN用于终止连接,ACK用于确认收到,RST用于重置连接(相当于异常终止连接),PSH用于指示接收方尽快把数据交给上层,URG用于表示TCP报文段中有紧急数据,CWR和ECE用于明确拥塞通告
  7. 明确拥塞通告: 当路由器发现网络拥塞后设置IP数据报的ECN比特,接收方收到这个ECN比特的信息后,将TCP报文段上面的ECE比特置为1,然后发回给发送方,发送方收到ECE信息后,以减半拥塞窗口作为回应,并在下一次发送TCP报文段时把报文段上的CWR比特置为1,以告诉接收方拥塞窗口已减半
  8. 接收窗口: 用于流量控制,是表示接收方接收缓冲还能容纳多少数据,发送方发送时会以接收窗口和拥塞窗口之中最小的为滑动窗口来流水线式发送数据
  9. 因特网校验和: 16位,即两个字节,用于检测TCP头和数据有无错误,将报文段以16比特为一个单位,全部相加,溢出的会在结果后面加一,最后得到一个16比特的数,此时因特网校验和加上这一个16比特的数后使得16比特全变为1,如果不是1那么就传输出错
  10. 紧急数据指针: 紧急数据的最后一个字节由16比特的紧急数据指针字段指出

UDP

  1. 源端口号和目的端口号: 用16bit表示所以端口号范围为0~65535,用来标识源主机和目的主机上的进程,用于运输层的多路复用和多路分解
  2. 长度: UDP是一次性发送上层的数据,不会像TCP一样将上层的报文进行分段处理,16bit最多可以表示65535个字节,是首部加数据的长度,首部长度固定8字节
  3. 因特网校验和: 16位,即两个字节,用于检测UDP头和数据有无错误,将报文段以16比特为一个单位,全部相加,溢出的会在结果后面加一,最后得到一个16比特的数,此时因特网校验和加上这一个16比特的数后使得16比特全变为1,如果不是1那么就传输出错

IP

  1. 版本: 4比特,最多表示16,用来标识是IPv4,还是IPv6
  2. 首部长度: 4比特,最多可以表示16个单位,每个单位是32比特即4个字节,所以最多可以表示64字节,所以IP首部最长为64字节,一般如果没有选项字段只有20字节
  3. 服务类型: 用于区分不同类型的数据报,如实时数据报(IP电话)和非实时流量(HTTP),IP电话要求低时延、高吞吐量、可靠性可以差点,但HTTP可以有时延,但是可靠性要求很好
  4. 数据报(包)长度: 16bit,理论上最多65535字节,但实际上很少超过1500字节,因为链路层的帧的负载一般最多1500字节(加上帧头最多1518字节,就是下面的以太网帧),IP数据包太长得分片
  5. 标识、标志、片偏移: 用于分片,标识号相当于TCP的序号,把包分片后给每个分片加一个标识,相邻的分片标识数差1,标志是为了指示接收方接收完成了,通常最后一个分片的标志比特设为0,其他的为1,片偏移相当于偏移量,用于指示该分片是在整个数据报的哪个位置,便于目的主机接收后重新组装
  6. 寿命: 8bit,最多255,IP数据报每经过一个路由器该字段减一,如果减为0,该数据报被丢弃
  7. 协议: 用于表示IP数据报要交给哪个上层运输层协议,值为6是TCP,值为17是UDP
  8. 首部检验和: 计算方式和上面一样,但是运输层首部检验和检验头和数据,IP只检验IP头,这样是为了提高转发效率
  9. 源和目的IP地址: 用于标识源主机和目的主机,而运输层的端口用于标识主机上面的进程

IPV6

  1. 版本: 4比特,最多表示16,用来标识是IPv4,还是IPv6
  2. 流量类型: 用于区分不同类型的数据报,如实时数据报(IP电话)和非实时流量(HTTP),IP电话要求低时延、高吞吐量、可靠性可以差点,但HTTP可以有时延,但是可靠性要求很好
  3. 流标签: 用于区分不同的流,和流量类型作用类似
  4. 有效载荷长度: 16bit,最大65535字节,IPv6不会分片,表示是数据长度不包括IPv6头部,因为IPv6头部固定是40字节
  5. 下一个首部: 相当于IPv4的选项字段,把选项放在下一个首部里面,而且可以表示上层协议的首部在什么位置,相当于指示了上层协议,可以理解为把选项和IPv4的协议字段融合起来
  6. 跳限制: 和寿命一样,8bit,最多255跳
  7. 源和目的IP地址: IPv6地址为128位

IPSec

ESP(Encapsulation Security Payload): 封装安全性载荷
SPI(Security Parameter Index): 安全参数索引

IPsec是为了加密IP数据报,加密步骤如下:

  1. 在初始IPv4数据报(包括首部和数据)后面附加一个ESP尾部
  2. 使用算法和SA(Security Association) 安全关联规定的密钥加密第一步结果
  3. 在加密后的数据附加ESP首部
  4. 使用算法和SA规定的密钥为上述所有生成一个MAC(Message Authentication Code)报文鉴别码即ESP MAC
  5. 将该MAC放在尾部
  6. 重新生成一个IPv4首部,这个新IP首部的地址是安全通道两端的地址,先经过安全通道传输,后面解密后再把里面初始IP数据报拿出来传输

以太网帧结构

  1. 前同步码: 前7个字节的值都是10101010,最后一个字节的值是10101011,前7个字节用于唤醒接收适配器,将接收方时钟和发送方时钟同步,为什么会不同步呢,因为适配器会以10Mbps、100Mbps、10Gbps传输速率,所以时钟不同,第8个字节最后两个11告诉适配器重要的内容要来了
  2. 目的地址和源地址: 即MAC(Media Access Control)地址,占6个字节,如AA-AA-AA-AA-AA
  3. 类型: 相当于IP数据报头里面的协议,指示上层协议(网络层),网络层不只有IP协议
  4. CRC : 循环冗余检验,比检验和更加强的检测,即数据比特一直和一个特定二进制序列异或,最后剩下的二进制串就是CRC,虽然可以检测错误,并把错误帧丢弃,但是没有重发机制,无法提供可靠性服务

802.1Q以太网帧结构


大部分和上面一样,802.1Q是一种扩展以太网格式,用于跨越VLAN干线的帧,新加入了一个VLAN标签,VLAN标签由2字节的标签协议标识符,一个2字节的标签控制信息字段和一个3比特优先权字段

802.11无线链路帧

  1. 帧控制: 类型和子类型用于区分关联、RTS、CTS、ACK和数据帧,从(form)和到(to)AP字段用于定义不同地址字段的含义(这些含义随着自组织模式或者基础设施模式而改变,而且在使用基础设施模式时,也随着是无线站点还是AP在发送帧而变化),WEP字段指示了是否使用加密
  2. 持续期: 802.11无线网络中可以预约信道,用于表示预约时长,在数据帧和RTS即CTS帧都存储,RTS(Request to Send)请求发送帧,CTS(Clear to Send)允许发送帧,
  3. RTS和CTS处理隐藏终端 当站点监听到信道空闲,等待DIFS(Distributed Inter-Frame Space)分布式帧间间隔后发送RTS,在发送RTS后接收方等待SIFS(Short Inter-Frame Spacing)短帧间间隔后发送CTS,然后发送方收到该CTS,等待SIFS后发送数据,最后接收完数据后接收方等待SIFS后发送ACK
  4. 地址字段: 每个地址都是一个MAC地址,地址2是传输该帧站点的MAC地址,地址1是要接收该帧的无线站点的MAC地址,地址3是路由器接口MAC地址,地址4是AP(Access Point)接入点自组织模式中互相转发时使用的地址
  5. 有效载荷: 包含有效数据,最大为2312字节,通常小于1500字节
  6. CRC: 循环冗余校验

SSL记录


可以看我这篇文章 SSL
前三个字段不加密

  1. 类型: 指出该字段是握手报文还是包含应用数据的报文,也可以用于关闭SSL连接
  2. 版本: 版本字段是自解释的
  3. 长度: 长度字段用来从到达的TCP自己流提取SSL记录,SSL记录是在TCP的上层的

RTP实时传输协议

  1. 有效载荷类型: 7比特,对于音频流有效载荷类型字段用于指示音频编码类型如(PCM、适应性增量调制、线性预测编码),通过改变类型可以提高语音质量和减少RTP流比特率(相当于降低质量)
  2. 序号: 16比特,用于检测丢包和恢复分组序列,每发送一个RTP分组则该序号加1
  3. 时间戳: 反映RTP数据分组中的第一个字节采样时刻
  4. 同步源标识符: 表示RTP流的源,表示发送方的IP地址,而是新的流开始时源随机分片的一个数

OpenFlow流表


计算机网络各层协议和操作抽象成匹配加动作转发表,即匹配某些字段,进行某些操作,如网络层路由器路由表,匹配IP转发数据报,都可以抽象为流表

参考

《计算机网络 自顶向下》

计算机网络11种协议报文格式相关推荐

  1. 【计算机网络】网络层 : BGP 协议 ( BGP 协议简介 | BGP 协议信息交换 | BGP 协议报文格式 | BGP-4 常用报文 | RIP 、OSPF、BGP 协议对比 )

    文章目录 一.路由选择协议分类 二.BGP 协议 简介 三.BGP 协议 信息交换过程 三.BGP 协议 报文格式 四.BGP 协议 特点 五.BGP-4 协议的 四种报文 六.RIP .OSPF.B ...

  2. 计算机网络-传输层(UDP协议报文格式,伪首部,UDP校验过程)

    文章目录 1. UDP协议 UDP报文格式 UDP校验过程 1. UDP协议 UDP只在IP数据报服务之上增加了很少功能,即复用分用和差错检测功能. UDP的主要特点: UDP是无连接的,减少开销和发 ...

  3. Bacnet协议报文格式详解(一)

    系统实现基于BACnet/IP(又称B/IP)网络进行通讯.BACnet虚拟链路层(BVLL)提供了BACnet网络层和某指定的通讯子系统的接口,本文指定了BACnet虚拟链路控制(BVLC)要求支持 ...

  4. MQTT协议详解及开发教程(四)MQTT协议报文格式

    推荐一款稳定的基于C编写的MQTT Client开源库 cMQTT MQTT协议详解及开发教程(一)MQTT协议概述 MQTT协议详解及开发教程(二)MQTT服务器EMQx搭建 MQTT协议详解及开发 ...

  5. “200+语种,11种文档格式”,百度文档翻译API,真的很好用

    五大功能亮点,全面满足您的需求 覆盖主流文档格式,包括11种常见文档格式:doc.docx.xls.xlsx.ppt.pptx.xml.html.htm.txt.pdf 支持200+语言互译,涵盖近4 ...

  6. 三菱MELSEC 1帧协议报文格式。

    关于三菱 MC 1E协议报文说明: 是不是1E协议可以发送:D100 .报文: 01ff0A00 64 00 00 00 20 44   0200 试试,返回报文:810000000000 报文格式: ...

  7. 计算机网络各层级协议报文形式详解

    网络层各级协议报文样式 概述 协议 所属层次 单位 长度 点对点协议 PPP 数据链路层 Mac帧 64~1518 IP协议 网络层 分组 packet 20~65535 UDP 运输层 数据报 8~ ...

  8. HTTP(超文本传输协议)报文格式

    HTTP请求报文 http请求报文数据分为三部分: 请求行 请求头部 请求数据 http请求报文的格式如下图所示: 下面是Get请求的例子: GET /92316461213.jpg HTTP/1.1 ...

  9. http协议报文格式原理图

    报文字段含义请参见:http协议报文字段含义

最新文章

  1. Word 2003文件保存和另存为操作是否熟练掌握的有关测试
  2. 又在GitHub上挖到个宝藏:Switch模拟器!
  3. 简述微型计算机的工作原理,高教自学考试微机原理及应用模拟试题
  4. Request.Url.Port 获取不到正确的端口号
  5. 为SAP Spartacus安装后台必须的Commerce Cloud
  6. 搜索技巧——持续更新
  7. 【TensorFlow】——索引与切片
  8. win10虚拟桌面使用方法-提高工作效率
  9. CocosCreator2.3.1按钮节点防止多次连续点击
  10. HTMl中3d变换卡片制作方法,CSS如何实现卡片3D翻转效果
  11. doors如何导入HTML文档,DOORS使用手册.doc
  12. build.gradle文件详解
  13. EasyRTMP手机直播推流到EasyDSS进行RTMP直播过程中分辨率反复切换崩溃问题解决
  14. 教你学Python38-利用SVD简化数据
  15. vue 音乐进度条拖拽
  16. 微信扫码登录_JAVA
  17. 【区块链 | Solidity】以太坊Solidity如何实现海量空投代币?
  18. javascript无限请求_SockJS - 重新连接后无限xhr-streaming呼叫
  19. 1.01_AFNetworking(4.0.1)源码分析(一)
  20. IBIS SPICE模型对比 (转帖)

热门文章

  1. python量化投资培训深圳你了解多少?
  2. 性能测试简单分析和调优
  3. PreziDesktop
  4. webstorm激活教程
  5. CICS集群安装相关要点记录
  6. python字符串去掉空行_从python中的字符串中删除空格
  7. 试利用记录型信号量和pv操作写出_三门峡c型槽钢抗震支架安装
  8. java断点续传_用Java实现断点续传(HTTP)
  9. c++ cin加速器
  10. 手机通讯录c语言导入手机软件,Total Control软件将手机通讯录导入导出的操作流程介绍...