CN110401513B - 一种数据传输方法和装置 - Google Patents
一种数据传输方法和装置 Download PDFInfo
- Publication number
- CN110401513B CN110401513B CN201910712743.4A CN201910712743A CN110401513B CN 110401513 B CN110401513 B CN 110401513B CN 201910712743 A CN201910712743 A CN 201910712743A CN 110401513 B CN110401513 B CN 110401513B
- Authority
- CN
- China
- Prior art keywords
- fragment
- data packet
- data
- serial number
- current
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L1/00—Arrangements for detecting or preventing errors in the information received
- H04L1/0001—Systems modifying transmission characteristics according to link quality, e.g. power backoff
- H04L1/0006—Systems modifying transmission characteristics according to link quality, e.g. power backoff by adapting the transmission format
- H04L1/0007—Systems modifying transmission characteristics according to link quality, e.g. power backoff by adapting the transmission format by modifying the frame length
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L69/00—Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
- H04L69/06—Notations for structuring of protocol data, e.g. abstract syntax notation one [ASN.1]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L69/00—Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
- H04L69/22—Parsing or analysis of headers
Abstract
本发明实施例提供了一种数据传输方法和装置,应用于视联网中,包括:获取当前待重组的分片数据包的分片头中的分片序号、分片哈希值和待传输数据;在预先建立的集合中存在哈希值的情况下,组包信息变量中的期待分片序号与当前分片数据包的分片序号不同,则将乱序集合中的与期待分片序号相同的分片数据包的待传输数据放入组包信息变量数据部分中的对应位置,若所述当前分片数据包为未分片数据包的最后一片,则获得重组后的所述未分片数据包。通过建立数据包所持有的乱序集合,解决了数据包在重组过程中的乱序问题,以适应视联网的数据负载部分可以来自于IP协议栈的各个层的需求。
Description
技术领域
本发明涉及视联网技术领域,特别是涉及一种数据传输方法和装置。
背景技术
随着网络科技的快速发展,视频会议、视频教学等双向通信在用户的生活、工作、学习等方面广泛普及,在双向通信的过程中,都会涉及到数据包的传输。
在数据包传输过程中,由于受到IP协议栈的各个层的最大负载或者是受到网络本身可传输负载的限制,单次发送的数据包的数据负载有上限限制若所需传输的数据包大于该负载上限,则发送数据包时需要拆包,在接收数据时就需要组包。
现有技术中还没有能够有效避免出现接收的数据包为乱序包的方案。
发明内容
鉴于上述问题,提出了本发明实施例以便提供一种克服上述问题或者至少部分地解决上述问题的一种数据传输方法和相应的一种数据传输装置。
本发明第一个方面提供一种数据传输方法,所述方法应用于视联网中,包括:
获取当前待重组的分片数据包的分片头中的分片序号、分片哈希值和待传输数据;
在预先建立的集合中存在所述哈希值的情况下,判断与所述哈希值相对应的组包信息变量中的期待分片序号是否与当前分片数据包的分片序号相同,其中,所述预先建立的集合中包括哈希值与组包信息变量,所述哈希值与所述组包信息变量相对应;
若所述组包信息变量中的期待分片序号与所述当前分片数据包的分片序号不同,则将乱序集合中的与所述期待分片序号相同的分片数据包的待传输数据放入所述组包信息变量数据部分中的对应位置,其中,所述乱序集合中存放在当前分片数据包之前接收到的分片数据包,且所述分片数据包的分片序号大于期待分片序号;
若所述当前分片数据包为未分片数据包的最后一片,则获得重组后的所述未分片数据包。
可选地,所述方法还包括:
获取待发送的数据包;
根据所述数据包的长度,计算所述数据包的分片数;
根据计算出的所述分片数,对所述数据包进行分片,其中,所述数据包包括分片头和待传输数据,所述分片头至少包括分片的源地址,目的地址、分片所属数据包的标识信息、分片的总片数,分片序号,分片的负载长度信息。
可选地,所述根据所述数据包的长度,计算所述数据包的分片数,包括:
分片数=(x+单次视联网最大负载-1)/单次视联网最大负载,其中,x表示待发送数据包的长度。
可选地,所述分片哈希值根据所述分片头中的源地址,目的地址和分片所属数据包的标识信息计算得到。
可选地,所述判断与所述哈希值相对应的组包信息变量中的期待分片序号是否与当前分片数据包的分片序号相同,还包括:
若所述组包信息变量中的期待分片序号与所述当前分片数据包的分片序号相同,则将所述当前分片数据包的待传输数据放入所述组包信息变量数据部分中的对应位置。
可选地,所述方法还包括:
若预先建立的集合中不存在所述哈希值,则将所述分片数据包的分片哈希值及待传输数据以所述组包信息变量进行保存,并采用键值插入所述集合中。
本发明第二个方面提供一种数据传输装置,所述装置应用于视联网中,包括:
获取模块,用于获取当前待重组的分片数据包的分片头中的分片序号、分片哈希值和待传输数据;
判断模块,用于在预先建立的集合中存在所述哈希值的情况下,判断与所述哈希值相对应的组包信息变量中的期待分片序号是否与当前分片数据包的分片序号相同,其中,所述预先建立的集合中包括哈希值与组包信息变量,所述哈希值与所述组包信息变量相对应;
重组模块,用于若所述组包信息变量中的期待分片序号与所述当前分片数据包的分片序号不同,则将乱序集合中的与所述期待分片序号相同的分片数据包的待传输数据放入所述组包信息变量数据部分中的对应位置,其中,所述乱序集合中存放在当前分片数据包之前接收到的分片数据包,且所述分片数据包的分片序号大于期待分片序号;
完成模块,用于若所述当前分片数据包为未分片数据包的最后一片,则获得重组后的所述未分片数据包。
可选地,所述装置还包括拆包模块,所述拆包模块用于:
获取待发送的数据包;
根据所述数据包的长度,计算所述数据包的分片数;
根据计算出的所述分片数,对所述数据包进行分片,其中,所述数据包包括分片头和待传输数据,所述分片头至少包括分片的源地址,目的地址、分片所属数据包的标识信息、分片的总片数,分片序号,分片的负载长度信息。
可选地,所述拆包模块具体用于:分片数=(x+单次视联网最大负载-1)/单次视联网最大负载,其中,x表示待发送数据包的长度。
可选地,所述分片哈希值根据所述分片头中的源地址,目的地址和分片所属数据包的标识信息计算得到。
可选地,重组模块还用于:若所述组包信息变量中的期待分片序号与所述当前分片数据包的分片序号相同,则将所述当前分片数据包的待传输数据放入所述组包信息变量数据部分中的对应位置。
可选地,判断模块还用于:
若预先建立的集合中不存在所述哈希值,则将所述分片数据包的分片哈希值及待传输数据以所述组包信息变量进行保存,并采用键值插入所述集合中。
本发明第三个方面提供一种电子设备,包括:至少一个处理器和存储器;
所述存储器存储计算机程序;所述至少一个处理器执行所述存储器存储的计算机程序,以实现第一个方面提供的方法。
本发明第四个方面提供一种计算机可读存储介质,该计算机可读存储介质中存储有计算机程序,所述计算机程序被执行时实现第一个方面提供的方法。
本发明实施例包括以下优点:
本发明实施例应用视联网的特性,提供的数据传输方法及装置,每次收到分片数据包时,获取到分片数据包的分片序号,判断当前分片数据包的分片序号和当前所期待分片序号是否一致,若当前分片数据包的分片序号大于当前所期待分片序号,则将当前分片数据包放入当前数据包所持有的乱序集合中;在对分片数据包进行重组时,若判断当前分片数据包的分片序号和当前所期待分片序号不一致,则从乱序集合中找到与当前所期待分片序号相同的乱序分片,执行拼包,直到当前分片数据包为最后一块,完成数据包的重组。通过建立数据包所持有的乱序集合,解决了数据包在重组过程中的乱序问题,以适应视联网的数据负载部分可以来自于IP协议栈的各个层的需求。
附图说明
图1是本发明的一种数据传输方法实施例的步骤流程图;
图2是本发明的又一种数据传输方法实施例的步骤流程图;
图3是本发明的再一种数据传输方法实施例的步骤流程图;
图4是本发明的一种数据传输装置实施例的结构示意图;
图5为本发明的一实施例提供的电子设备的结构示意图。
具体实施方式
为使本发明的上述目的、特征和优点能够更加明显易懂,下面结合附图和具体实施方式对本发明作进一步详细的说明。
视联网是网络发展的重要里程碑,是一个实时网络,能够实现高清视频实时传输,将众多互联网应用推向高清视频化,高清面对面。
视联网采用实时高清视频交换技术,可以在一个网络平台上将所需的服务,如高清视频会议、视频监控、智能化监控分析、应急指挥、数字广播电视、延时电视、网络教学、现场直播、VOD点播、电视邮件、个性录制(PVR)、内网(自办)频道、智能化视频播控、信息发布等数十种视频、语音、图片、文字、通讯、数据等服务全部整合在一个系统平台,通过电视或电脑实现高清品质视频播放。
为使本领域技术人员更好地理解本发明实施例,以下对视联网进行介绍:
1、视联网数据包定义
1.1接入网数据包定义
接入网的数据包主要包括以下几部分:目的地址(DA)、源地址(SA)、保留字节、payload(PDU)、CRC。
如下表所示,接入网的数据包主要包括以下几部分:
DA | SA | Reserved | Payload | CRC |
其中:
目的地址(DA)由8个字节(byte)组成,第一个字节表示数据包的类型(例如各种协议包、组播数据包、单播数据包等),最多有256种可能,第二字节到第六字节为城域网地址,第七、第八字节为接入网地址;
源地址(SA)也是由8个字节(byte)组成,定义与目的地址(DA)相同;
保留字节由2个字节组成;
payload部分根据不同的数据报的类型有不同的长度,如果是各种协议包的话是64个字节,如果是单组播数据包话是32+1024=1056个字节,当然并不仅仅限于以上2种;
CRC有4个字节组成,其计算方法遵循标准的以太网CRC算法。
1.2城域网数据包定义
城域网的拓扑是图型,两个设备之间可能有2种、甚至2种以上的连接,即节点交换机和节点服务器、节点交换机和节点交换机、节点交换机和节点服务器之间都可能超过2种连接。但是,城域网设备的城域网地址却是唯一的,为了精确描述城域网设备之间的连接关系,在本发明实施例中引入参数:标签,来唯一描述一个城域网设备。
本说明书中标签的定义和MPLS(Multi-Protocol Label Switch,多协议标签交换)的标签的定义类似,假设设备A和设备B之间有两个连接,那么数据包从设备A到设备B就有2个标签,数据包从设备B到设备A也有2个标签。标签分入标签、出标签,假设数据包进入设备A的标签(入标签)是0x0000,这个数据包离开设备A时的标签(出标签)可能就变成了0x0001。城域网的入网流程是集中控制下的入网过程,也就意味着城域网的地址分配、标签分配都是由城域服务器主导的,节点交换机、节点服务器都是被动的执行而已,这一点与MPLS的标签分配是不同的,MPLS的标签分配是交换机、服务器互相协商的结果。
如下表所示,城域网的数据包主要包括以下几部分:
DA | SA | Reserved | 标签 | Payload | CRC |
即目的地址(DA)、源地址(SA)、保留字节(Reserved)、标签、payload(PDU)、CRC。其中,标签的格式可以参考如下定义:标签是32bit,其中高16bit保留,只用低16bit,它的位置是在数据包的保留字节和payload之间。
分片:因视联网单次传输数据长度的限制,数据包无法一次传输,因此需要将数据包拆成若干分片,多次传输才能将一个数据包传输完。
基于视联网的上述特性,提出了本发明实施例的核心构思之一,遵循视联网的协议,通过建立数据包所持有的乱序集合,判断当前分片数据包的分片序号与期待分片序号,对接收到的分片数据包进行重组,解决了数据包在重组过程中的乱序问题,以适应视联网的数据负载部分可以来自于IP协议栈的各个层的需求。
本发明一实施例提供一种数据传输方法,用于对接收到分片数据包进行重组。本实施例的执行主体为数据传输方法装置,该装置可以设置在视联网设备上,可以是计算机、平板电脑及手机终端等。
图1是本发明的一种数据传输方法实施例的步骤流程图,如图1所示,该方法应用于视联网中,该方法包括:
S101、获取当前待重组的分片数据包的分片头中的分片序号、分片哈希值和待传输数据;
具体地,在视联网数据传输过程中,发送端设备将数据包进行分片,每个分片数据包包括分片头和待传输数据,其中,分片头中包括分片所在包的标识信息(即ID号),分片的总片数,分片序号,分片的负载长度等,在发送端发送数据包时的拆包过程填写分片头,再由接收端接收分片数据包的组包过程中根据分片头进行组包;
例如,总共有10个数据包要传输,将每个数据包分为5个分片数据包,当前的分片数据包为第8个数据包的第3片,即分片所在包的标识信息为第8个,分片的总片数为50,分片序号为3,分片的负载长度为8k,其中,负载长度可以根据实际需要进行设定。
分片的数据部分:数据包在拆包后,其数据部分会分散在各个分片数据包的数据部分中,具体的分片数据包可以根据实际需要进行拆分。
发送端将分片数据包发送到视联网中,接收端接收到分片数据包,获取到当前分片数据包的分片头中的分片序号、分片哈希值和待传输数据。
S102、在预先建立的集合中存在所述哈希值的情况下,判断与所述哈希值相对应的组包信息变量中的期待分片序号是否与当前分片数据包的分片序号相同,其中,所述预先建立的集合中包括哈希值与组包信息变量,所述哈希值与所述组包信息变量相对应;
具体地,预先建立的集合例如map A用来存放待重组的数据包信息(即下面的组包信息变量B),具体包括分片的哈希值与组包信息变量,且哈希值与组包信息变量相对应。
若一个数据包重组完成,会将该数据包对应的组包信息变量从该集合中删除。若所有数据都重组完成后,则将该集合mapA删除。
组包信息变量valueB包括待重组分片数据包的数据部分和期待分片序号等,并且存储在上述的集合mapA中。
接收端在获取到当前分片数据包的哈希值后,在预先建立的集合中进行查找,若集合中存在当前数据包的哈希值,则判断与哈希值相对应的组包信息变量中的期待分片序号是否与当前分片数据包的分片序号相同。
S103、若所述组包信息变量中的期待分片序号与所述当前分片数据包的分片序号不同,则将乱序集合中的与所述期待分片序号相同的分片数据包的待传输数据放入所述组包信息变量数据部分中的对应位置,其中,所述乱序集合中存放在当前分片数据包之前接收到的分片数据包,且所述分片数据包的分片序号大于期待分片序号;
具体地,每个组包信息变量B持有一个乱序集合C,乱序集合C用于存放当前分片数据包之前接收到的分片数据包(即分片序号大于期待分片序号的),以便在后续分片数据包重组时进行查找。例如,若期待分片序号为2,则当前接收到分片数据包的分片序号为3,则将接收到的分片数据包存放在该分片数据包对应的乱序集合中,在后续重组时,若期待分片序号为3时,调用该分片数据包。
接收端判断集合中存在当前数据包的哈希值,则判断组包信息变量中的期待分片序号与所述当前分片数据包的分片序号,若两者不相同,则在乱序集合中查找与期待分片序号相同的乱序分片,将乱序分片中的待传输数据放入所述组包信息变量数据部分中的对应位置,并将期待分片序号的数值加1。
S104、若所述当前分片数据包为未分片数据包的最后一片,则获得重组后的所述未分片数据包。
判断当前分片数据包为分片数据包的最后一片时,则获得重组后的数据包,删除集合map A中的组包信息变量及乱序集合C中对应的数据。
本实施例提供的数据传输方法,每次收到分片数据包时,获取到分片数据包的分片序号,判断当前分片数据包的分片序号和当前所期待分片序号是否一致,若当前分片数据包的分片序号大于当前所期待分片序号,则将当前分片数据包放入当前数据包所持有的乱序集合中;在对分片数据包进行重组时,若判断当前分片数据包的分片序号和当前所期待分片序号不一致,则从乱序集合中找到与当前所期待分片序号相同的乱序分片,执行拼包,直到当前分片数据包为最后一块,完成数据包的重组。通过建立数据包所持有的乱序集合,解决了数据包在重组过程中的乱序问题,以适应视联网的数据负载部分可以来自于IP协议栈的各个层的需求。
本发明又一实施例对上述实施例提供的方法做进一步补充说明。
在上述实施例的基础上,可选地,所述方法还包括:
获取待发送的数据包;
根据所述数据包的长度,计算所述数据包的分片数;
根据计算出的所述分片数,对所述数据包进行分片,其中,所述数据包包括分片头和待传输数据,所述分片头至少包括分片的源地址,目的地址、分片所属数据包的标识信息、分片的总片数,分片序号,分片的负载长度信息。
图2是本发明的又一种数据传输方法实施例的步骤流程图,如图2所示,数据传输过程中不仅包括数据包重组也就是数据包拼包过程,还包括数据包的拆包过程也就是拆片过程,具体地:
S201、获取一个待发送的数据包;
S202、计算数据包应该拆成多少分片;
S203、将分片的所在包的标识数据包,分片的总片数,分片序号,分片的负载长度、目的地址和源地址等信息填写到各分片头中;
S204、将数据包中的对应各分片的数据部分拷贝到各分片中;
S205、发送数据包的各分片到视联网。
在上述实施例的基础上,可选地,所述根据所述数据包的长度,计算所述数据包的分片数,包括:
分片数=(x+单次视联网最大负载-1)/单次视联网最大负载,其中,x表示待发送数据包的长度。
具体地,本发明实施例提供的拆片过程不限制数据包最终拆得的片数,可以根据待传输数据包的长度来计算可以拆分的片数,例如:一般一个数据包的上限为65535字节,因此最大可拆片数=(65535+单次视联网最大负载-1)/单次视联网最大负载,其中,单次视联网最大负载可以根据IP协议栈的各个层的不同需求进行设定。
可选地,所述分片哈希值根据所述分片头中的源地址,目的地址和分片所属数据包的标识信息计算得到。
具体地,分片数据包的哈希hash值根据分片头中的源mac地址,目的mac地址和所在数据包的标识信息计算得出,各个数据包的hash值用key表示,该hash值可唯一标识一个数据包。每次收到的分片数据包可根据hash值来判断是否来着同一个数据包。若两个分片的hash值相同,则代表这两个分片属于同一个数据包。
可选地,所述判断与所述哈希值相对应的组包信息变量中的期待分片序号是否与当前分片数据包的分片序号相同,还包括:
若所述组包信息变量中的期待分片序号与所述当前分片数据包的分片序号相同,则将所述当前分片数据包的待传输数据放入所述组包信息变量数据部分中的对应位置,并将期待分片序号的值加1。
可选地,所述方法还包括:
若预先建立的集合中不存在所述哈希值,则将所述分片数据包的分片哈希值及待传输数据以所述组包信息变量进行保存,并采用键值插入所述集合中。
图3是本发明的再一种数据传输方法实施例的步骤流程图,如图3所示,具体地:
S301、接收到一个分片数据包;
S302、根据该分片数据包头中的源mac地址,目的mac地址和所在包id计算出hash值(一种将任意长度的消息压缩到某一固定长度的消息摘要的函数)。
S303、将hash作为key,在集合map A中查找该hash。
S304、若在集合A中找到哈希值,将找到的哈希值对应的value值(期待分片序号和数据部分)作为当前分片的组包信息,保存为变量B;
S305、若在集合A中未找到哈希值,则将哈希值及分片的数据内容作为组包信息并以变量B进行保存组包信息,并将键值对<hash,B>插入map A中。
S306、通过当前分片头中的分片序号和组包信息B中的期待分片序号做比较,判断当前分片是否为所期待的分片,若是,则执行S308,若否,则执行S307。
S307、判断当前分片的分片序号是否大于期待分片号,若是,执行S311,若否,执行S312,组包过程结束。
S308、若当前分片头中的分片序号和组包信息B中的期待分片序号相同,则将当前分片的数据部分拷贝到当前组包信息中的数据包的相应位置,并将期待分片号+1。
S309、判断当前分片是否是最后一片,若是,则执行S313,若不是,则执行S310。
S310、从乱序集合C中查找是否有符合期待片号的分片,若是,则重复执行S309,若否,则组包过程结束。
S311、将分片放入乱序集合C中,组包过程结束。
S312、丢弃分片。
S313、拿到重组后的数据包,删除map A中乱序集合C中对应的数据资源,组包过程结束。
需要说明的是,本实施例中各可实施的方式可以单独实施,也可以在不冲突的情况下以任意组合方式结合实施本发明不做限定。
本发明实施例提供的数据传输方法,每次收到分片数据包时,获取到分片数据包的分片序号,判断当前分片数据包的分片序号和当前所期待分片序号是否一致,若当前分片数据包的分片序号大于当前所期待分片序号,则将当前分片数据包放入当前数据包所持有的乱序集合中;在对分片数据包进行重组时,若判断当前分片数据包的分片序号和当前所期待分片序号不一致,则从乱序集合中找到与当前所期待分片序号相同的乱序分片,执行拼包,直到当前分片数据包为最后一块,完成数据包的重组。通过建立数据包所持有的乱序集合,解决了数据包在重组过程中的乱序问题,以适应视联网的数据负载部分可以来自于IP协议栈的各个层的需求。
需要说明的是,对于方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应该知悉,本发明实施例并不受所描述的动作顺序的限制,因为依据本发明实施例,某些步骤可以采用其他顺序或者同时进行。其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于优选实施例,所涉及的动作并不一定是本发明实施例所必须的。
本发明另一实施例提供一种数据传输装置,用于执行上述实施例提供的方法。
图4是本发明的一种数据传输装置实施例的结构示意图,如图4所示,该数据传输装置包括获取模块401、判断模块402、重组模块403和完成模块404,其中:获取模块401用于获取当前待重组的分片数据包的分片头中的分片序号、分片哈希值和待传输数据;
判断模块402用于在预先建立的集合中存在所述哈希值的情况下,判断与所述哈希值相对应的组包信息变量中的期待分片序号是否与当前分片数据包的分片序号相同,其中,所述预先建立的集合中包括哈希值与组包信息变量,所述哈希值与所述组包信息变量相对应;
重组模块403用于若所述组包信息变量中的期待分片序号与所述当前分片数据包的分片序号不同,则将乱序集合中的与所述期待分片序号相同的分片数据包的待传输数据放入所述组包信息变量数据部分中的对应位置,其中,所述乱序集合中存放在当前分片数据包之前接收到的分片数据包,且所述分片数据包的分片序号大于期待分片序号;
完成模块404用于若所述当前分片数据包为未分片数据包的最后一片,则获得重组后的所述未分片数据包。
关于本实施例中的装置,其中各个模块执行操作的具体方式已经在有关该方法的实施例中进行了详细描述,此处将不做详细阐述说明。
根据本发明实施例提供的数据传输装置,每次收到分片数据包时,获取到分片数据包的分片序号,判断当前分片数据包的分片序号和当前所期待分片序号是否一致,若当前分片数据包的分片序号大于当前所期待分片序号,则将当前分片数据包放入当前数据包所持有的乱序集合中;在对分片数据包进行重组时,若判断当前分片数据包的分片序号和当前所期待分片序号不一致,则从乱序集合中找到与当前所期待分片序号相同的乱序分片,执行拼包,直到当前分片数据包为最后一块,完成数据包的重组。通过建立数据包所持有的乱序集合,解决了数据包在重组过程中的乱序问题,以适应视联网的数据负载部分可以来自于IP协议栈的各个层的需求。
本发明又一实施例对上述实施例提供的装置做进一步补充说明。
可选地,所述装置还包括拆包模块,所述拆包模块用于:
获取待发送的数据包;
根据所述数据包的长度,计算所述数据包的分片数;
根据计算出的所述分片数,对所述数据包进行分片,其中,所述数据包包括分片头和待传输数据,所述分片头至少包括分片的源地址,目的地址、分片所属数据包的标识信息、分片的总片数,分片序号,分片的负载长度信息。
可选地,所述拆包模块具体用于:分片数=(x+单次视联网最大负载-1)/单次视联网最大负载,其中,x表示待发送数据包的长度。
可选地,所述分片哈希值根据所述分片头中的源地址,目的地址和分片所属数据包的标识信息计算得到。
可选地,重组模块还用于:若所述组包信息变量中的期待分片序号与所述当前分片数据包的分片序号相同,则将所述当前分片数据包的待传输数据放入所述组包信息变量数据部分中的对应位置。
可选地,判断模块还用于:
若预先建立的集合中不存在所述哈希值,则将所述分片数据包的分片哈希值及待传输数据以所述组包信息变量进行保存,并采用键值插入所述集合中。
关于本实施例中的装置,其中各个模块执行操作的具体方式已经在有关该方法的实施例中进行了详细描述,此处将不做详细阐述说明。
需要说明的是,本实施例中各可实施的方式可以单独实施,也可以在不冲突的情况下以任意组合方式结合实施本发明不做限定。
根据本实施例的数据传输装置,每次收到分片数据包时,获取到分片数据包的分片序号,判断当前分片数据包的分片序号和当前所期待分片序号是否一致,若当前分片数据包的分片序号大于当前所期待分片序号,则将当前分片数据包放入当前数据包所持有的乱序集合中;在对分片数据包进行重组时,若判断当前分片数据包的分片序号和当前所期待分片序号不一致,则从乱序集合中找到与当前所期待分片序号相同的乱序分片,执行拼包,直到当前分片数据包为最后一块,完成数据包的重组。通过建立数据包所持有的乱序集合,解决了数据包在重组过程中的乱序问题,以适应视联网的数据负载部分可以来自于IP协议栈的各个层的需求。
本说明书中的各个实施例均采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似的部分互相参见即可。
本发明再一实施例提供一种电子设备,用于执行上述实施例提供的方法。
图5为本发明一实施例提供的电子设备的结构示意图,如图5所示,该电子设备包括:至少一个处理器51和存储器52;
所述存储器存储计算机程序;所述至少一个处理器执行所述存储器存储的计算机程序,以实现上述实施例提供的方法。
根据本实施例的电子设备,每次收到分片数据包时,获取到分片数据包的分片序号,判断当前分片数据包的分片序号和当前所期待分片序号是否一致,若当前分片数据包的分片序号大于当前所期待分片序号,则将当前分片数据包放入当前数据包所持有的乱序集合中;在对分片数据包进行重组时,若判断当前分片数据包的分片序号和当前所期待分片序号不一致,则从乱序集合中找到与当前所期待分片序号相同的乱序分片,执行拼包,直到当前分片数据包为最后一块,完成数据包的重组。通过建立数据包所持有的乱序集合,解决了数据包在重组过程中的乱序问题,以适应视联网的数据负载部分可以来自于IP协议栈的各个层的需求。
本发明又一实施例提供一种计算机可读存储介质,该计算机可读存储介质中存储有计算机程序,所述计算机程序被执行时实现上述任一实施例提供的方法。
根据本实施例的计算机可读存储介质,每次收到分片数据包时,获取到分片数据包的分片序号,判断当前分片数据包的分片序号和当前所期待分片序号是否一致,若当前分片数据包的分片序号大于当前所期待分片序号,则将当前分片数据包放入当前数据包所持有的乱序集合中;在对分片数据包进行重组时,若判断当前分片数据包的分片序号和当前所期待分片序号不一致,则从乱序集合中找到与当前所期待分片序号相同的乱序分片,执行拼包,直到当前分片数据包为最后一块,完成数据包的重组。通过建立数据包所持有的乱序集合,解决了数据包在重组过程中的乱序问题,以适应视联网的数据负载部分可以来自于IP协议栈的各个层的需求。本领域内的技术人员应明白,本发明实施例的实施例可提供为方法、装置、或计算机程序产品。因此,本发明实施例可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明实施例可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本发明实施例是参照根据本发明实施例的方法、终端设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理终端设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理终端设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理终端设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理终端设备上,使得在计算机或其他可编程终端设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程终端设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
尽管已描述了本发明实施例的优选实施例,但本领域内的技术人员一旦得知了基本创造性概念,则可对这些实施例做出另外的变更和修改。所以,所附权利要求意欲解释为包括优选实施例以及落入本发明实施例范围的所有变更和修改。
最后,还需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者终端设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者终端设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者终端设备中还存在另外的相同要素。
以上对本发明所提供的一种数据传输方法和一种数据传输装置,进行了详细介绍,本文中应用了具体个例对本发明的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本发明的方法及其核心思想;同时,对于本领域的一般技术人员,依据本发明的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本发明的限制。
Claims (9)
1.一种数据传输方法,其特征在于,所述方法应用于视联网中,包括:
获取当前待重组的分片数据包的分片头中的分片序号、分片哈希值和待传输数据;所述分片头还包括分片的源地址,目的地址、分片所属数据包的标识信息、分片的总片数,分片的负载长度信息;所述分片哈希值根据所述分片头中的源地址,目的地址和分片所属数据包的标识信息计算得到;
在预先建立的集合中存在所述哈希值的情况下,判断与所述哈希值相对应的组包信息变量中的期待分片序号是否与当前分片数据包的分片序号相同,其中,所述预先建立的集合中包括哈希值与组包信息变量,所述哈希值与所述组包信息变量相对应;
若所述组包信息变量中的期待分片序号与所述当前分片数据包的分片序号不同,则将乱序集合中的与所述期待分片序号相同的分片数据包的待传输数据放入所述组包信息变量数据部分中的对应位置,将接收到的当前分片数据包存放在所述分片数据包对应的乱序集合中,其中,所述乱序集合中存放在当前分片数据包之前接收到的分片数据包,且所述分片数据包的分片序号大于期待分片序号;
若所述当前分片数据包为未分片数据包的最后一片,则获得重组后的所述未分片数据包。
2.根据权利要求1所述的方法,其特征在于,所述方法还包括:
获取待发送的数据包;
根据所述数据包的长度,计算所述数据包的分片数;
根据计算出的所述分片数,对所述数据包进行分片,其中,所述数据包包括分片头和待传输数据。
3.根据权利要求2所述的方法,其特征在于,所述根据所述数据包的长度,计算所述数据包的分片数,包括:
分片数=(x+单次视联网最大负载-1)/单次视联网最大负载,其中,x表示待发送数据包的长度。
4.根据权利要求1所述的方法,其特征在于,所述判断与所述哈希值相对应的组包信息变量中的期待分片序号是否与当前分片数据包的分片序号相同,还包括:
若所述组包信息变量中的期待分片序号与所述当前分片数据包的分片序号相同,则将所述当前分片数据包的待传输数据放入所述组包信息变量数据部分中的对应位置。
5.根据权利要求1所述的方法,其特征在于,所述方法还包括:
若预先建立的集合中不存在所述哈希值,则将所述分片数据包的分片哈希值及待传输数据以所述组包信息变量进行保存,并采用键值插入所述集合中。
6.一种数据传输装置,其特征在于,所述装置应用于视联网中,包括:
获取模块,用于获取当前待重组的分片数据包的分片头中的分片序号、分片哈希值和待传输数据;所述分片头还包括分片的源地址,目的地址、分片所属数据包的标识信息、分片的总片数,分片的负载长度信息;所述分片哈希值根据所述分片头中的源地址,目的地址和分片所属数据包的标识信息计算得到;
判断模块,用于在预先建立的集合中存在所述哈希值的情况下,判断与所述哈希值相对应的组包信息变量中的期待分片序号是否与当前分片数据包的分片序号相同,其中,所述预先建立的集合中包括哈希值与组包信息变量,所述哈希值与所述组包信息变量相对应;
重组模块,用于若所述组包信息变量中的期待分片序号与所述当前分片数据包的分片序号不同,则将乱序集合中的与所述期待分片序号相同的分片数据包的待传输数据放入所述组包信息变量数据部分中的对应位置,将接收到的当前分片数据包存放在所述分片数据包对应的乱序集合中,其中,所述乱序集合中存放在当前分片数据包之前接收到的分片数据包,且所述分片数据包的分片序号大于期待分片序号;
完成模块,用于若所述当前分片数据包为未分片数据包的最后一片,则获得重组后的所述未分片数据包。
7.根据权利要求6所述的装置,其特征在于,所述装置还包括拆包模块,所述拆包模块用于:
获取待发送的数据包;
根据所述数据包的长度,计算所述数据包的分片数;
根据计算出的所述分片数,对所述数据包进行分片,其中,所述数据包包括分片头和待传输数据,所述分片头至少包括分片的源地址,目的地址、分片所属数据包的标识信息、分片的总片数,分片序号,分片的负载长度信息。
8.一种电子设备,其特征在于,包括:至少一个处理器和存储器;
所述存储器存储计算机程序;所述至少一个处理器执行所述存储器存储的计算机程序,以实现权利要求1-5中任一项所述的方法。
9.一种计算机可读存储介质,其特征在于,该计算机可读存储介质中存储有计算机程序,所述计算机程序被执行时实现权利要求1-5中任一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910712743.4A CN110401513B (zh) | 2019-08-02 | 2019-08-02 | 一种数据传输方法和装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910712743.4A CN110401513B (zh) | 2019-08-02 | 2019-08-02 | 一种数据传输方法和装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN110401513A CN110401513A (zh) | 2019-11-01 |
CN110401513B true CN110401513B (zh) | 2021-12-17 |
Family
ID=68327287
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201910712743.4A Active CN110401513B (zh) | 2019-08-02 | 2019-08-02 | 一种数据传输方法和装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN110401513B (zh) |
Families Citing this family (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112243160A (zh) * | 2020-09-14 | 2021-01-19 | 视联动力信息技术股份有限公司 | 一种数据传输方法、装置、终端设备和存储介质 |
CN113364862B (zh) * | 2021-06-03 | 2022-10-11 | 上海天旦网络科技发展有限公司 | 一种拼包解码系统及方法 |
CN114465966A (zh) * | 2022-01-23 | 2022-05-10 | 山东云海国创云计算装备产业创新中心有限公司 | 一种数据包重组控制系统和数据包重组方法 |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101662418A (zh) * | 2008-08-26 | 2010-03-03 | 华为技术有限公司 | 一种传输文件的检测方法及终端 |
CN101697631A (zh) * | 2009-10-28 | 2010-04-21 | 中兴通讯股份有限公司 | 一种可序数据包的乱序调整方法及装置 |
WO2010075795A1 (zh) * | 2008-12-31 | 2010-07-08 | 华为技术有限公司 | 分片信息处理的方法和装置 |
CN108683635A (zh) * | 2018-04-12 | 2018-10-19 | 国家计算机网络与信息安全管理中心 | 一种基于网络处理芯片实现ip分片包同源同宿的系统及方法 |
CN109889779A (zh) * | 2019-01-31 | 2019-06-14 | 视联动力信息技术股份有限公司 | 一种报文乱序的处理方法和装置 |
-
2019
- 2019-08-02 CN CN201910712743.4A patent/CN110401513B/zh active Active
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101662418A (zh) * | 2008-08-26 | 2010-03-03 | 华为技术有限公司 | 一种传输文件的检测方法及终端 |
WO2010075795A1 (zh) * | 2008-12-31 | 2010-07-08 | 华为技术有限公司 | 分片信息处理的方法和装置 |
CN101697631A (zh) * | 2009-10-28 | 2010-04-21 | 中兴通讯股份有限公司 | 一种可序数据包的乱序调整方法及装置 |
CN108683635A (zh) * | 2018-04-12 | 2018-10-19 | 国家计算机网络与信息安全管理中心 | 一种基于网络处理芯片实现ip分片包同源同宿的系统及方法 |
CN109889779A (zh) * | 2019-01-31 | 2019-06-14 | 视联动力信息技术股份有限公司 | 一种报文乱序的处理方法和装置 |
Also Published As
Publication number | Publication date |
---|---|
CN110401513A (zh) | 2019-11-01 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110401513B (zh) | 一种数据传输方法和装置 | |
CN109391560B (zh) | 网络拥塞的通告方法、代理节点及计算机设备 | |
CN110086578B (zh) | 数据传输方法、装置和系统 | |
CA2442439C (en) | Packet transmission system and packet reception system | |
EP3211852A1 (en) | Ssh protocol-based session parsing method and system | |
EP2166799A1 (en) | Method and apparatus for implementing a virtual network | |
CN108574818B (zh) | 一种信息显示的方法、装置和服务器 | |
CN109996086B (zh) | 一种视联网业务状态查询方法及装置 | |
CN110086850B (zh) | 一种文件的处理方法和视联网网盘系统 | |
CN109474715B (zh) | 一种基于视联网的资源配置方法和装置 | |
CN110809026B (zh) | 一种文件处理方法、装置、电子设备及存储介质 | |
CN110730143B (zh) | 一种分片数据包处理方法及装置 | |
CN110493344B (zh) | 文件下载方法和装置 | |
CN110519009B (zh) | 一种数据包传输方法和装置 | |
CN110381119B (zh) | 一种日志信息的获取方法、系统及装置和存储介质 | |
CN110138513B (zh) | 一种数据传输方法和视联网系统 | |
CN109451001B (zh) | 一种通讯方法和系统 | |
CN103067745A (zh) | 一种视频数据的切分方法及装置、在线编辑方法及系统 | |
CN106789655B (zh) | 一种路由通告报文的发送方法和装置 | |
CN110557370B (zh) | 一种pamir同步终端信息的方法、系统、电子设备及存储介质 | |
CN109861929B (zh) | 一种数据缓存处理的方法和装置 | |
CN112243160A (zh) | 一种数据传输方法、装置、终端设备和存储介质 | |
CN110062259B (zh) | 视频获取方法、系统、设备和计算机可读存储介质 | |
CN109451030B (zh) | 一种视联网文件的下载方法和系统 | |
CN110493555B (zh) | 请求处理方法、用户终端、核心服务器、设备及存储介质 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |