CN110138513A - 一种数据传输方法和视联网系统 - Google Patents
一种数据传输方法和视联网系统 Download PDFInfo
- Publication number
- CN110138513A CN110138513A CN201910233379.3A CN201910233379A CN110138513A CN 110138513 A CN110138513 A CN 110138513A CN 201910233379 A CN201910233379 A CN 201910233379A CN 110138513 A CN110138513 A CN 110138513A
- Authority
- CN
- China
- Prior art keywords
- data
- terminal
- critical
- sent
- module
- 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.)
- Granted
Links
- 230000005540 biological transmission Effects 0.000 title claims abstract description 100
- 238000000034 method Methods 0.000 title claims abstract description 64
- 238000012790 confirmation Methods 0.000 claims abstract description 63
- 230000006855 networking Effects 0.000 claims description 38
- 230000008569 process Effects 0.000 claims description 13
- 238000006243 chemical reaction Methods 0.000 claims description 9
- 238000004891 communication Methods 0.000 claims description 9
- 238000005194 fractionation Methods 0.000 claims description 3
- 238000005516 engineering process Methods 0.000 description 19
- 238000010586 diagram Methods 0.000 description 13
- 238000012545 processing Methods 0.000 description 8
- 238000004590 computer program Methods 0.000 description 7
- 238000001514 detection method Methods 0.000 description 6
- 230000006870 function Effects 0.000 description 6
- 238000009826 distribution Methods 0.000 description 5
- 230000007246 mechanism Effects 0.000 description 5
- RTZKZFJDLAIYFH-UHFFFAOYSA-N Diethyl ether Chemical compound CCOCC RTZKZFJDLAIYFH-UHFFFAOYSA-N 0.000 description 4
- 238000003860 storage Methods 0.000 description 3
- 238000004364 calculation method Methods 0.000 description 2
- 230000008859 change Effects 0.000 description 2
- 238000011161 development Methods 0.000 description 2
- 230000000694 effects Effects 0.000 description 2
- 238000005538 encapsulation Methods 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 238000012544 monitoring process Methods 0.000 description 2
- 230000011664 signaling Effects 0.000 description 2
- 238000011144 upstream manufacturing Methods 0.000 description 2
- 241000700605 Viruses Species 0.000 description 1
- 238000004458 analytical method Methods 0.000 description 1
- 230000002155 anti-virotic effect Effects 0.000 description 1
- 238000004422 calculation algorithm Methods 0.000 description 1
- 125000004122 cyclic group Chemical group 0.000 description 1
- 238000012217 deletion Methods 0.000 description 1
- 230000037430 deletion Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 239000000284 extract Substances 0.000 description 1
- 230000003993 interaction Effects 0.000 description 1
- 238000004519 manufacturing process Methods 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 230000000750 progressive effect Effects 0.000 description 1
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/0078—Avoidance of errors by organising the transmitted data in a format specifically designed to deal with errors, e.g. location
-
- 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/12—Arrangements for detecting or preventing errors in the information received by using return channel
- H04L1/16—Arrangements for detecting or preventing errors in the information received by using return channel in which the return channel carries supervisory signals, e.g. repetition request signals
- H04L1/1607—Details of the supervisory signal
-
- 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/16—Implementation or adaptation of Internet protocol [IP], of transmission control protocol [TCP] or of user datagram protocol [UDP]
- H04L69/165—Combined use of TCP and UDP protocols; selection criteria therefor
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Computer Security & Cryptography (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
本发明实施例提供了一种数据传输方法和视联网系统,所述方法包括:接收第一终端发送的UDP格式的第一数据;当第一数据包含回包确认标识时,向第一终端发送第一确认信息;将第一数据转换为TCP格式的第二数据;根据预设规则将第二数据拆分为关键数据和/或非关键数据;将非关键数据转换为UDP格式的第三数据并发送至第二终端;将关键数据发送至第二终端并并计时;当检测到数据传输过程超出预设时长时,向第二终端重新发送关键数据。本发明中流媒体服务器负责终端设备之间的数据传输的回包确认,并将传输数据进行拆分并通过TCP和UDP两种协议分开进行传输,不仅减轻了端对端数据传输的压力,还保障了端对端数据传输的可靠性和高效性。
Description
技术领域
本发明涉及视联网技术领域,特别是涉及一种数据传输方法和视联网系统。
背景技术
视联网是网络发展的重要里程碑,是互联网的更高级形态,是一个实时网络,能够实现目前互联网无法实现的全网高清视频实时传输,将众多互联网应用推向高清视频化。其中,视联网通过流媒体服务器实现终端设备之间的媒体流传输。
传统的视联网流媒体服务器通常是采用TCP或者UDP的网络传输协议进行端对服务器之间的信令、媒体流交互。传统的UDP协议是在不考虑传输是否成功的前提下,持续向对端发送数据直至数据传输完成,具有数据传输效率高的特点。传统的TCP协议是要去对端数据接收完成后返回确认包,否则将重新发送,这种机制避免了数据传输过程中的数据丢失。
但是TCP网络传输协议在网络环境恶劣时由于存在重传包机制,由于数据传输缓慢会一直重复向流媒体服务器发送数据,导致数据阻塞的问题,而UDP网络传输协议虽然会一直持续发包不考虑是否正常发送到对端,但由于没有包确认、重传包的机制,会导致数据包大量丢失的问题。这就使得视联网数据传输的可靠性和高效性无法同时得到保障。
发明内容
鉴于上述问题,提出了本发明实施例以便提供一种克服上述问题或者至少部分地解决上述问题的一种数据传输方法和视联网系统。
为了解决上述问题,本发明实施例第一方面公开了一种数据传输方法,所述方法应用于视联网系统中的流媒体服务器,所述流媒体服务器用于实现第一终端与第二终端之间的通信连接,所述方法包括:
接收所述第一终端发送的UDP格式的第一数据;
当所述第一数据包含回包确认标识时,向所述第一终端发送第一确认信息;
将所述第一数据转换为TCP格式的第二数据;
根据预设规则将所述第二数据拆分为关键数据和/或非关键数据;
将所述非关键数据转换为UDP格式的第三数据,并将所述第三数据发送至所述第二终端;
将所述关键数据发送至所述第二终端,并对所述关键数据的数据传输过程进行计时;
当检测到所述数据传输过程超出预设时长时,向所述第二终端重新发送所述关键数据。
可选的,所述接收所述第一终端发送的UDP格式的第一数据的步骤之后,还包括:
当所述第一数据包含第二终端的确认信息标识时,停止所述第一数据的传输并删除所述第一数据。
可选的,所述根据预设规则将所述第二数据拆分为关键数据和/或非关键数据,包括:
解析所述第二数据;
通过给所述第二数据中符合预设数据类型的数据添加重传标识,生成关键数据;
利用所述第二数据中不符合所述预设数据类型的数据生成非关键数据。
可选的,所述将所述关键数据发送至所述第二终端,并对所述关键数据的数据传输过程进行计时,包括:
当所述关键数据包含所述重传标识时,将所述关键数据发送至所述第二终端,并对所述关键数据传输过程进行计时。
可选的,所述将所述非关键数据转换为UDP格式的第三数据,并将所述第三数据发送至所述第二终端的步骤之后,还包括:
接收所述第二终端返回的第二确认信息。
本发明实施例第二方面公开了一种数据传输视联网系统,所述视联网系统包括:流媒体服务器,所述流媒体服务器用于实现第一终端与第二终端之间的通信连接,所述流媒体服务器包括:
接收模块,用于接收所述第一终端发送的UDP格式的第一数据;
回复确认模块,用于当所述第一数据包含回包确认标识时,向所述第一终端发送第一确认信息;
第一转换模块,用于将所述第一数据转换为TCP格式的第二数据;
拆分模块,用于根据预设规则将所述第二数据拆分为关键数据和/或非关键数据;
第二转换模块,用于将所述非关键数据转换为UDP格式的第三数据,并将所述第三数据发送至所述第二终端;
计时模块,用于将所述关键数据发送至所述第二终端,并对所述关键数据的数据传输过程进行计时;
重传模块,用于当检测到所述数据传输过程超出预设时长时,向所述第二终端重新发送所述关键数据。
可选的,所述流媒体服务器,还包括:
停删模块,用于当所述第一数据包含第二终端的确认信息标识时,停止所述第一数据的传输并删除所述第一数据。
可选的,所述拆分模块,包括:
解析子模块,用于解析所述第二数据;
第一生成子模块,用于通过给所述第二数据中符合预设数据类型的数据添加重传标识,生成关键数据;
第二生成子模块,用于利用所述第二数据中不符合所述预设数据类型的数据生成非关键数据。
可选的,所述计时模块,包括:
计时子模块,用于当所述关键数据包含所述重传标识时,将所述关键数据发送至所述第二终端,并对所述关键数据传输过程进行计时。
可选的,所述流媒体服务器,还包括:
接收确认模块,用于接收所述第二终端返回的第二确认信息。
本发明实施例包括以下优点:
本发明实施例提供了一种数据传输方法和视联网系统,所述方法包括:接收第一终端发送的UDP格式的第一数据;当第一数据包含回包确认标识时,向第一终端发送第一确认信息;将第一数据转换为TCP格式的第二数据;根据预设规则将第二数据拆分为关键数据和/或非关键数据;将非关键数据转换为UDP格式的第三数据并发送至第二终端;将关键数据发送至第二终端并进行计时;当检测到数据传输过程超出预设时长时,向第二终端重新发送关键数据。本发明实施例由流媒体服务器负责终端设备之间的数据传输的回包确认,并将传输的数据进行拆分后通过TCP和UDP两种协议分别进行传输,不仅减轻了端对端数据传输的压力,还保障了端对端数据传输的可靠性和高效性。
附图说明
图1是本发明的一种视联网的组网示意图;
图2是本发明的一种节点服务器的硬件结构示意图;
图3是本发明的一种接入交换机的硬件结构示意图;
图4是本发明的一种以太网协转网关的硬件结构示意图;
图5是本发明的一种数据传输时,数据传输过程的示意图;
图6是本发明的一种数据传输方法的步骤流程图;
图7是本发明的一种数据传输视联网系统的结构框图。
具体实施方式
为使本发明的上述目的、特征和优点能够更加明显易懂,下面结合附图和具体实施方式对本发明作进一步详细的说明。
视联网是网络发展的重要里程碑,是一个实时网络,能够实现高清视频实时传输,将众多互联网应用推向高清视频化,高清面对面。
视联网采用实时高清视频交换技术,可以在一个网络平台上将所需的服务,如高清视频会议、视频监控、智能化监控分析、应急指挥、数字广播电视、延时电视、网络教学、现场直播、VOD点播、电视邮件、个性录制(PVR)、内网(自办)频道、智能化视频播控、信息发布等数十种视频、语音、图片、文字、通讯、数据等服务全部整合在一个系统平台,通过电视或电脑实现高清品质视频播放。
为使本领域技术人员更好地理解本发明实施例,以下对视联网进行介绍:
视联网所应用的部分技术如下所述:
网络技术(Network Technology)
视联网的网络技术创新改良了传统以太网(Ethernet),以面对网络上潜在的巨大视频流量。不同于单纯的网络分组包交换(Packet Switching)或网络电路交换(CircuitSwitching),视联网技术采用Packet Switching满足Streaming需求。视联网技术具备分组交换的灵活、简单和低价,同时具备电路交换的品质和安全保证,实现了全网交换式虚拟电路,以及数据协议的无缝连接。
交换技术(Switching Technology)
视联网采用以太网的异步和包交换两个优点,在全兼容的前提下消除了以太网缺陷,具备全网端到端无缝连接,直通用户终端,直接承载IP数据包。用户数据在全网范围内不需任何协议转换。视联网是以太网的更高级形态,是一个实时交换平台,能够实现目前互联网无法实现的全网大规模高清视频实时传输,将众多网络视频应用推向高清化、统一化。
服务器技术(Server Technology)
视联网和统一视频平台上的服务器技术不同于传统意义上的服务器,它的流媒体传输是建立在面向连接的基础上,其数据处理能力与流量、通讯时间无关,单个网络层就能够包含信令及数据传输。对于语音和视频业务来说,视联网和统一视频平台流媒体处理的复杂度比数据处理简单许多,效率比传统服务器大大提高了百倍以上。
储存器技术(Storage Technology)
统一视频平台的超高速储存器技术为了适应超大容量和超大流量的媒体内容而采用了最先进的实时操作系统,将服务器指令中的节目信息映射到具体的硬盘空间,媒体内容不再经过服务器,瞬间直接送达到用户终端,用户等待一般时间小于0.2秒。最优化的扇区分布大大减少了硬盘磁头寻道的机械运动,资源消耗仅占同等级IP互联网的20%,但产生大于传统硬盘阵列3倍的并发流量,综合效率提升10倍以上。
网络安全技术(Network Security Technology)
视联网的结构性设计通过每次服务单独许可制、设备与用户数据完全隔离等方式从结构上彻底根除了困扰互联网的网络安全问题,一般不需要杀毒程序、防火墙,杜绝了黑客与病毒的攻击,为用户提供结构性的无忧安全网络。
服务创新技术(Service Innovation Technology)
统一视频平台将业务与传输融合在一起,不论是单个用户、私网用户还是一个网络的总合,都不过是一次自动连接。用户终端、机顶盒或PC直接连到统一视频平台,获得丰富多彩的各种形态的多媒体视频服务。统一视频平台采用“菜谱式”配表模式来替代传统的复杂应用编程,可以使用非常少的代码即可实现复杂的应用,实现“无限量”的新业务创新。
视联网的组网如下所述:
视联网是一种集中控制的网络结构,该网络可以是树型网、星型网、环状网等等类型,但在此基础上网络中需要有集中控制节点来控制整个网络。
如图1所示,视联网分为接入网和城域网两部分。
接入网部分的设备主要可以分为3类:节点服务器,接入交换机,终端(包括各种机顶盒、编码板、存储器等)。节点服务器与接入交换机相连,接入交换机可以与多个终端相连,并可以连接以太网。
其中,节点服务器是接入网中起集中控制功能的节点,可控制接入交换机和终端。节点服务器可直接与接入交换机相连,也可以直接与终端相连。
类似的,城域网部分的设备也可以分为3类:城域服务器,节点交换机,节点服务器。城域服务器与节点交换机相连,节点交换机可以与多个节点服务器相连。
其中,节点服务器即为接入网部分的节点服务器,即节点服务器既属于接入网部分,又属于城域网部分。
城域服务器是城域网中起集中控制功能的节点,可控制节点交换机和节点服务器。城域服务器可直接连接节点交换机,也可直接连接节点服务器。
由此可见,整个视联网络是一种分层集中控制的网络结构,而节点服务器和城域服务器下控制的网络可以是树型、星型、环状等各种结构。
形象地称,接入网部分可以组成统一视频平台(虚线圈中部分),多个统一视频平台可以组成视联网;每个统一视频平台可以通过城域以及广域视联网互联互通。
视联网设备分类
1.1本发明实施例的视联网中的设备主要可以分为3类:服务器,交换机(包括以太网网关),终端(包括各种机顶盒,编码板,存储器等)。视联网整体上可以分为城域网(或者国家网、全球网等)和接入网。
1.2其中接入网部分的设备主要可以分为3类:节点服务器,接入交换机(包括以太网网关),终端(包括各种机顶盒,编码板,存储器等)。
各接入网设备的具体硬件结构为:
节点服务器:
如图2所示,主要包括网络接口模块201、交换引擎模块202、CPU模块203、磁盘阵列模块204;
其中,网络接口模块201,CPU模块203、磁盘阵列模块204进来的包均进入交换引擎模块202;交换引擎模块202对进来的包进行查地址表205的操作,从而获得包的导向信息;并根据包的导向信息把该包存入对应的包缓存器206的队列;如果包缓存器206的队列接近满,则丢弃;交换引擎模202轮询所有包缓存器队列,如果满足以下条件进行转发:1)该端口发送缓存未满;2)该队列包计数器大于零。磁盘阵列模块204主要实现对硬盘的控制,包括对硬盘的初始化、读写等操作;CPU模块203主要负责与接入交换机、终端(图中未示出)之间的协议处理,对地址表205(包括下行协议包地址表、上行协议包地址表、数据包地址表)的配置,以及,对磁盘阵列模块204的配置。
接入交换机:
如图3所示,主要包括网络接口模块(下行网络接口模块301、上行网络接口模块302)、交换引擎模块303和CPU模块304;
其中,下行网络接口模块301进来的包(上行数据)进入包检测模块305;包检测模块305检测包的目地地址(DA)、源地址(SA)、数据包类型及包长度是否符合要求,如果符合,则分配相应的流标识符(stream-id),并进入交换引擎模块303,否则丢弃;上行网络接口模块302进来的包(下行数据)进入交换引擎模块303;CPU模块304进来的数据包进入交换引擎模块303;交换引擎模块303对进来的包进行查地址表306的操作,从而获得包的导向信息;如果进入交换引擎模块303的包是下行网络接口往上行网络接口去的,则结合流标识符(stream-id)把该包存入对应的包缓存器307的队列;如果该包缓存器307的队列接近满,则丢弃;如果进入交换引擎模块303的包不是下行网络接口往上行网络接口去的,则根据包的导向信息,把该数据包存入对应的包缓存器307的队列;如果该包缓存器307的队列接近满,则丢弃。
交换引擎模块303轮询所有包缓存器队列,在本发明实施例中分两种情形:
如果该队列是下行网络接口往上行网络接口去的,则满足以下条件进行转发:1)该端口发送缓存未满;2)该队列包计数器大于零;3)获得码率控制模块产生的令牌;
如果该队列不是下行网络接口往上行网络接口去的,则满足以下条件进行转发:1)该端口发送缓存未满;2)该队列包计数器大于零。
码率控制模块308是由CPU模块304来配置的,在可编程的间隔内对所有下行网络接口往上行网络接口去的包缓存器队列产生令牌,用以控制上行转发的码率。
CPU模块304主要负责与节点服务器之间的协议处理,对地址表306的配置,以及,对码率控制模块308的配置。
以太网协转网关:
如图4所示,主要包括网络接口模块(下行网络接口模块401、上行网络接口模块402)、交换引擎模块403、CPU模块404、包检测模块405、码率控制模块408、地址表406、包缓存器407和MAC添加模块409、MAC删除模块410。
其中,下行网络接口模块401进来的数据包进入包检测模块405;包检测模块405检测数据包的以太网MAC DA、以太网MAC SA、以太网length or frame type、视联网目地地址DA、视联网源地址SA、视联网数据包类型及包长度是否符合要求,如果符合则分配相应的流标识符(stream-id);然后,由MAC删除模块410减去MAC DA、MAC SA、length or frame type(2byte),并进入相应的接收缓存,否则丢弃;
下行网络接口模块401检测该端口的发送缓存,如果有包则根据包的视联网目地地址DA获知对应的终端的以太网MAC DA,添加终端的以太网MAC DA、以太网协转网关的MACSA、以太网length or frame type,并发送。
以太网协转网关中其他模块的功能与接入交换机类似。
终端:
主要包括网络接口模块、业务处理模块和CPU模块;例如,机顶盒主要包括网络接口模块、视音频编解码引擎模块、CPU模块;编码板主要包括网络接口模块、视音频编码引擎模块、CPU模块;存储器主要包括网络接口模块、CPU模块和磁盘阵列模块。
1.3城域网部分的设备主要可以分为2类:节点服务器,节点交换机,城域服务器。其中,节点交换机主要包括网络接口模块、交换引擎模块和CPU模块;城域服务器主要包括网络接口模块、交换引擎模块和CPU模块构成。
2、视联网数据包定义
2.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算法。
2.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之间。
基于视联网的上述特性,提出了本发明实施例的核心构思之一,遵循视联网的协议,由流媒体服务器负责第一终端和第二终端之间的数据传输的回包确认和数据处理。
在本发明实施例中,视联网系统包括流媒体服务器,第一终端,第二终端。
参照图5,在本发明实施例中,流媒体服务器501与第一终端502、第二终端503之间分别是通过视联网进行传输。
实施例一
参照图6,示出了本发明的一种数据传输方法实施例的步骤流程图,所述方法应用于视联网中的流媒体服务器,所述流媒体服务器用于实现第一终端与第二终端之间的通信连接,所述方法包括:
步骤601,接收所述第一终端发送的UDP格式的第一数据。
在本发明实施例中,所述流媒体服务器用于实现视联网中终端设备之间的媒体流传输。所述第一终端将需要发送给所述第二终端的原始数据按照UDP协议进行打包,得到所述UDP格式的第一数据。
所述第一终端还可以给所述第一数据的封装包头上添加确认信息标识,第二终端的确认信息标识。
可选的,所述步骤601之后,还包括:
步骤A1,当所述第一数据包含第二终端的确认信息标识时,停止所述第一数据的传输并删除所述第一数据。
在本发明实施例中,所述流媒体服务器在接受到所述第一终端发送的所述第一数据时,先判断所述第一数据中是否包含所述第二终端的确认信息标识,以判别所述第一数据是否是所述第二终端向所述第一终端发送数据后返回的确认信息。
当所述第一数据中包含第二终端的确认信息标识时,从所述流媒体服务器的临时列队中删除所述第一数据以停止所述第一数据的发送。
本发明实施例通过在流媒体服务器对回包确认的确认信息进行和拦截,使得终端设备在向流媒体服务器发送数据后无需再参与确认过程,从而可以直接执行其他的数据传输任务,减少了端对端数据传输中终端设备的数据传输压力,提高了端对端数据传输的效率。
步骤602,当所述第一数据包含回包确认标识时,向所述第一终端发送第一确认信息。
在本发明实施例中,所述流媒体服务器在检测到所述第一数据包含回报确认标识时,向所述第一终端返回相应的第一确认信息,以使得在采用UDP协议进行数据传输时,也可以实现回包确认的机制。
步骤603,将所述第一数据转换为TCP格式的第二数据。
在本发明实施例中,所述流媒体服务器将UDP格式的所述第一数据通过UDP-TCP协议进行转换得到TCP格式的所述第二数据,并将所述第二数据放入到原有的TCP逻辑用户的接受队列中。
步骤604,根据预设规则将所述第二数据拆分为关键数据和/或非关键数据。
在本发明实施例中,为了提高所述第二数据的数据传输效率,可以根据实际需要制定预设规则,将所述第二数据进行拆分为关键数据和/或非关键数据以采用不同的传输方式分开传输。所述关键数据和非关键数据可以是包含部分所述第二数据中的数据,也可以为空。操作人员可以通过配置预设规则进行设置。
可选的,所述步骤604,包括:
子步骤B1,解析所述第二数据。
在本发明实施例中,所述流媒体服务器将所述第二数据进行解包,提取所述第二数据中的数据。
子步骤B2,通过给所述第二数据中符合预设数据类型的数据添加重传标识,生成关键数据。
在本发明实施例中,在数据传输的过程中,基于实际需要,数据中的某种数据类型的数据往往在整个数据包整体中具有关键性的作用,例如在实际应用中的全景高清视频数据,画面中心位置的高清视频数据是实现全景直播的关键,而处于画面边缘位置的标清视频数据的重要性远低于中心部分的高清视频数据。所述关键数据在数据传输中的重要性使得该数据类型的数据不允许丢失,因此所述流媒体服务器根据预设数据类型在所述第二数据中的关键信息进行标识封装,从而生成所述关键数据。
子步骤B3,利用所述第二数据中不符合所述预设数据类型的数据生成非关键数据。
在本发明实施例中,依据上述步骤B2,当从所述第二数据中提取并生成所述关键数据后,剩余的所述第二数据中的数据可作为非关键数据。
本发明实施例通过添加重传标识的方式将第二数据进行拆分为关键数据和非关键数据,减轻了数据重传机制的数据传输压力。
步骤605,将所述非关键数据转换为UDP格式的第三数据,并将所述第三数据发送至所述第二终端。
在本发明实施例中,所述流媒体服务器将所述非关键数据根据TCP-UDP协议进行转换获取UDP格式的所述第三数据,可以理解,所述第三数据允许在数据传输过程中出现丢失的。然后将所述第三数据通过UDP传输器发送至所述第二终端。
可选的,所述步骤605之后,还包括:
步骤C1,接收所述第二终端返回的第二确认信息。
在本发明实施例中,所述第三数据还可以包括所述第一终端的回复确认标识;所述第二终端在接收到所述第三数据后,根据所述回复确认标识向所述流媒体服务器返回相对应的所述第二确认信息。参照步骤A1,所述流媒体服务器接收到所述第二确认信息后会停止所述第二确认信息向所述第一终端发送的进程,并删除所述第二确认信息。
本发明实施例通过在UDP协议进行发送非关键数据后,在流媒体服务器侧对所述第二确认信息进行接收并删除,无需所述第一终端再参与信息确认过程,减轻了端对端数据传输中终端设备的数据传输压力。
步骤606,将所述关键数据发送至所述第二终端,并对所述关键数据的数据传输过程进行计时。
在本发明实施例中,所述流媒体服务器将所述关键数据采用TCP协议发送至所述第二终端,并在在本地对所述关键数据的数据传输过程进行计时。
可选的,所述步骤606,包括:
子步骤D1,当所述关键数据包含所述重传标识时,将所述关键数据发送至所述第二终端,并对所述关键数据传输过程进行计时。
在本发明实施例中,当所述流媒体服务器检测到所述关键数据包含所述重传标识时,确认所述关键数据的数据传输过程需要添加重传机制所述流媒体服务器将所述关键数据采用TCP协议发送至所述第二终端,并在在本地对所述关键数据的数据传输过程进行计时。
步骤607,当检测到所述数据传输过程超出预设时长时,向所述第二终端重新发送所述关键数据。
在本发明实施例中,当所述流媒体服务器内的计时器检测到所述关键数据的数据传输过程到达预设时长时还未完成,即未收到所述第二终端返回的确认信息的情况下,向所述第二终端重新发送所述关键数据,直至在预设时长内接收到第二终端返回的确认信息,停止重新发送,可以保证所述关键数据可以完整传输至所述第二终端。
本发明实施例提供了一种数据传输方法,所述方法包括:接收第一终端发送的UDP格式的第一数据;当第一数据包含回包确认标识时,向第一终端发送第一确认信息;将第一数据转换为TCP格式的第二数据;根据预设规则将第二数据拆分为关键数据和/或非关键数据;将非关键数据转换为UDP格式的第三数据并发送至第二终端;将关键数据发送至第二终端并进行计时;当检测到数据传输过程超出预设时长时,向第二终端重新发送关键数据。本发明实施例由流媒体服务器负责终端设备之间的数据传输的回包确认,并将传输的数据进行拆分后通过TCP和UDP两种协议分别进行传输,不仅减轻了端对端数据传输的压力,还保障了端对端数据传输的可靠性和高效性。
实施例二
参照图7,示出了本发明的一种数据传输视联网系统70实施例的结构框图,所述视联网系统70包括:流媒体服务器701,所述流媒体服务器701用于实现第一终端702与第二终端703之间的通信连接,所述流媒体服务器701包括:
接收模块7011,用于接收所述第一终端发送的UDP格式的第一数据。
可选的,所述流媒体服务器701,还包括:
停删模块E1,用于当所述第一数据包含第二终端的确认信息标识时,停止所述第一数据的传输并删除所述第一数据。
回复确认模块7012,用于当所述第一数据包含回包确认标识时,向所述第一终端发送第一确认信息。
第一转换模块7013,用于将所述第一数据转换为TCP格式的第二数据。
拆分模块7014,用于根据预设规则将所述第二数据拆分为关键数据和/或非关键数据。
可选的,所述拆分模块7014,包括:
解析子模块F1,用于解析所述第二数据。
第一生成子模块F2,用于通过给所述第二数据中符合预设数据类型的数据添加重传标识,生成关键数据。
第二生成子模块F3,用于利用所述第二数据中不符合所述预设数据类型的数据生成非关键数据。
第二转换模块7015,用于将所述非关键数据转换为UDP格式的第三数据,并将所述第三数据发送至所述第二终端。
计时模块7016,用于将所述关键数据发送至所述第二终端,并对所述关键数据的数据传输过程进行计时。
可选的,所述计时模块7016,包括:
计时子模块G1,用于当所述关键数据包含所述重传标识时,将所述关键数据发送至所述第二终端,并对所述关键数据传输过程进行计时。
重传模块7017,用于当检测到所述数据传输过程超出预设时长时,向所述第二终端重新发送所述关键数据。
可选的,所述流媒体服务器701,还包括:
接收确认模块H1,用于接收所述第二终端返回的第二确认信息。
本发明实施例提供了一种数据传输方法和视联网系统,所述视联网系统包括:流媒体服务器,所述流媒体服务器用于实现第一终端与第二终端之间的通信连接,所述流媒体服务器包括:接收模块,用于接收所述第一终端发送的UDP格式的第一数据;回复确认模块,用于当所述第一数据包含回包确认标识时,向所述第一终端发送第一确认信息;第一转换模块,用于将所述第一数据转换为TCP格式的第二数据;拆分模块,用于根据预设规则将所述第二数据拆分为关键数据和/或非关键数据;第二转换模块,用于将所述非关键数据转换为UDP格式的第三数据,并将所述第三数据发送至所述第二终端;计时模块,用于将所述关键数据发送至所述第二终端,并对所述关键数据的数据传输过程进行计时;重传模块,用于当检测到所述数据传输过程超出预设时长时,向所述第二终端重新发送所述关键数据。本发明实施例由流媒体服务器负责终端设备之间的数据传输的回包确认,并将传输的数据进行拆分后通过TCP和UDP两种协议分别进行传输,不仅减轻了端对端数据传输的压力,还保障了端对端数据传输的可靠性和高效性。
对于视联网系统实施例而言,由于其与方法实施例基本相似,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
本说明书中的各个实施例均采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似的部分互相参见即可。
本领域内的技术人员应明白,本发明实施例的实施例可提供为方法、视联网系统、或计算机程序产品。因此,本发明实施例可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明实施例可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本发明实施例是参照根据本发明实施例的方法、终端设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理终端设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理终端设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的视联网系统。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理终端设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令视联网系统的制造品,该指令视联网系统实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理终端设备上,使得在计算机或其他可编程终端设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程终端设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
尽管已描述了本发明实施例的优选实施例,但本领域内的技术人员一旦得知了基本创造性概念,则可对这些实施例做出另外的变更和修改。所以,所附权利要求意欲解释为包括优选实施例以及落入本发明实施例范围的所有变更和修改。
最后,还需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者终端设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者终端设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者终端设备中还存在另外的相同要素。
以上对本发明所提供的一种数据传输方法和一种数据传输视联网系统,进行了详细介绍,本文中应用了具体个例对本发明的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本发明的方法及其核心思想;同时,对于本领域的一般技术人员,依据本发明的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本发明的限制。
Claims (10)
1.一种数据传输方法,其特征在于,所述方法应用于视联网中的流媒体服务器,所述流媒体服务器用于实现第一终端与第二终端之间的通信连接,所述方法包括:
接收所述第一终端发送的UDP格式的第一数据;
当所述第一数据包含回包确认标识时,向所述第一终端发送第一确认信息;
将所述第一数据转换为TCP格式的第二数据;
根据预设规则将所述第二数据拆分为关键数据和/或非关键数据;
将所述非关键数据转换为UDP格式的第三数据,并将所述第三数据发送至所述第二终端;
将所述关键数据发送至所述第二终端,并对所述关键数据的数据传输过程进行计时;
当检测到所述数据传输过程超出预设时长时,向所述第二终端重新发送所述关键数据。
2.根据权利要求1所述的方法,其特征在于,所述接收所述第一终端发送的UDP格式的第一数据的步骤之后,还包括:
当所述第一数据包含第二终端的确认信息标识时,停止所述第一数据的传输并删除所述第一数据。
3.根据权利要求1所述的方法,其特征在于,所述根据预设规则将所述第二数据拆分为关键数据和/或非关键数据,包括:
解析所述第二数据;
通过给所述第二数据中符合预设数据类型的数据添加重传标识,生成关键数据;
利用所述第二数据中不符合所述预设数据类型的数据生成非关键数据。
4.根据权利要求3所述的方法,其特征在于,所述将所述关键数据发送至所述第二终端,并对所述关键数据的数据传输过程进行计时,包括:
当所述关键数据包含所述重传标识时,将所述关键数据发送至所述第二终端,并对所述关键数据传输过程进行计时。
5.根据权利要求1所述的方法,其特征在于,所述将所述非关键数据转换为UDP格式的第三数据,并将所述第三数据发送至所述第二终端的步骤之后,还包括:
接收所述第二终端返回的第二确认信息。
6.一种视联网系统,其特征在于,所述视联网系统包括:流媒体服务器,所述流媒体服务器用于实现第一终端与第二终端之间的通信连接,所述流媒体服务器包括:
接收模块,用于接收所述第一终端发送的UDP格式的第一数据;
回复确认模块,用于当所述第一数据包含回包确认标识时,向所述第一终端发送第一确认信息;
第一转换模块,用于将所述第一数据转换为TCP格式的第二数据;
拆分模块,用于根据预设规则将所述第二数据拆分为关键数据和/或非关键数据;
第二转换模块,用于将所述非关键数据转换为UDP格式的第三数据,并将所述第三数据发送至所述第二终端;
计时模块,用于将所述关键数据发送至所述第二终端,并对所述关键数据的数据传输过程进行计时;
重传模块,用于当检测到所述数据传输过程超出预设时长时,向所述第二终端重新发送所述关键数据。
7.根据权利要求6所述的视联网系统,其特征在于,所述流媒体服务器,还包括:
停删模块,用于当所述第一数据包含第二终端的确认信息标识时,停止所述第一数据的传输并删除所述第一数据。
8.根据权利要求6所述的视联网系统,其特征在于,所述拆分模块,包括:
解析子模块,用于解析所述第二数据;
第一生成子模块,用于通过给所述第二数据中符合预设数据类型的数据添加重传标识,生成关键数据;
第二生成子模块,用于利用所述第二数据中不符合所述预设数据类型的数据生成非关键数据。
9.根据权利要求8所述的视联网系统,其特征在于,所述计时模块,包括:
计时子模块,用于当所述关键数据包含所述重传标识时,将所述关键数据发送至所述第二终端,并对所述关键数据传输过程进行计时。
10.根据权利要求6所述的视联网系统,其特征在于,所述流媒体服务器,还包括:
接收确认模块,用于接收所述第二终端返回的第二确认信息。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910233379.3A CN110138513B (zh) | 2019-03-26 | 2019-03-26 | 一种数据传输方法和视联网系统 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910233379.3A CN110138513B (zh) | 2019-03-26 | 2019-03-26 | 一种数据传输方法和视联网系统 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN110138513A true CN110138513A (zh) | 2019-08-16 |
CN110138513B CN110138513B (zh) | 2020-12-29 |
Family
ID=67568605
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201910233379.3A Active CN110138513B (zh) | 2019-03-26 | 2019-03-26 | 一种数据传输方法和视联网系统 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN110138513B (zh) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110381028A (zh) * | 2019-06-19 | 2019-10-25 | 视联动力信息技术股份有限公司 | 一种数据传输方法和视联网服务器 |
CN113449337A (zh) * | 2021-06-22 | 2021-09-28 | 广州市资拓科技有限公司 | 一种服务器托管信息处理方法及系统 |
WO2021232376A1 (zh) * | 2020-05-21 | 2021-11-25 | 华为技术有限公司 | 一种音频数据传输方法及相关装置 |
Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20060098616A1 (en) * | 2004-11-05 | 2006-05-11 | Ruckus Wireless, Inc. | Throughput enhancement by acknowledgement suppression |
CN103078831A (zh) * | 2011-10-26 | 2013-05-01 | 新太科技股份有限公司 | 一种流媒体支持tcp和udp传送的自适应的方法 |
CN104618337A (zh) * | 2014-12-31 | 2015-05-13 | 浙江理工大学 | 一种基于tcp/udp混合协议的流媒体无线自适应传输方法 |
KR20150094435A (ko) * | 2014-02-11 | 2015-08-19 | 한국전자통신연구원 | 단기 신뢰성을 갖는 영상데이터 전송 방법 |
US20170048296A1 (en) * | 2015-08-14 | 2017-02-16 | Cisco Technology, Inc. | Timely Delivery of Real-Time Media Problem When TCP Must Be Used |
CN107113474A (zh) * | 2015-02-13 | 2017-08-29 | Sk电信有限公司 | 具有记录在其上以用于提供低延迟直播内容的程序的记录介质和装置 |
CN107104945A (zh) * | 2010-06-04 | 2017-08-29 | 斯凯普爱尔兰科技控股公司 | 服务器辅助的视频会话 |
CN108881932A (zh) * | 2017-11-24 | 2018-11-23 | 北京视联动力国际信息技术有限公司 | 一种视频播放的方法和装置 |
CN109068147A (zh) * | 2018-09-18 | 2018-12-21 | 腾讯科技(深圳)有限公司 | 一种多媒体数据传输方法、装置以及相关设备 |
-
2019
- 2019-03-26 CN CN201910233379.3A patent/CN110138513B/zh active Active
Patent Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20060098616A1 (en) * | 2004-11-05 | 2006-05-11 | Ruckus Wireless, Inc. | Throughput enhancement by acknowledgement suppression |
CN107104945A (zh) * | 2010-06-04 | 2017-08-29 | 斯凯普爱尔兰科技控股公司 | 服务器辅助的视频会话 |
CN103078831A (zh) * | 2011-10-26 | 2013-05-01 | 新太科技股份有限公司 | 一种流媒体支持tcp和udp传送的自适应的方法 |
KR20150094435A (ko) * | 2014-02-11 | 2015-08-19 | 한국전자통신연구원 | 단기 신뢰성을 갖는 영상데이터 전송 방법 |
CN104618337A (zh) * | 2014-12-31 | 2015-05-13 | 浙江理工大学 | 一种基于tcp/udp混合协议的流媒体无线自适应传输方法 |
CN107113474A (zh) * | 2015-02-13 | 2017-08-29 | Sk电信有限公司 | 具有记录在其上以用于提供低延迟直播内容的程序的记录介质和装置 |
US20170048296A1 (en) * | 2015-08-14 | 2017-02-16 | Cisco Technology, Inc. | Timely Delivery of Real-Time Media Problem When TCP Must Be Used |
CN108881932A (zh) * | 2017-11-24 | 2018-11-23 | 北京视联动力国际信息技术有限公司 | 一种视频播放的方法和装置 |
CN109068147A (zh) * | 2018-09-18 | 2018-12-21 | 腾讯科技(深圳)有限公司 | 一种多媒体数据传输方法、装置以及相关设备 |
Non-Patent Citations (2)
Title |
---|
KEVIN GATIMU ; ARUL DHAMODARAN ; TAYLOR JOHNSON ; BEN LEE: ""Experimental study of low-latency HD VoD streaming using flexible dual TCP-UDP streaming protocol"", 《 2018 15TH IEEE ANNUAL CONSUMER COMMUNICATIONS & NETWORKING CONFERENCE (CCNC)》 * |
彭麒菱: ""P2P实时流媒体服务器的设计与实现"", 《中国优秀硕士学位论文全文数据库(电子期刊)信息科技辑》 * |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110381028A (zh) * | 2019-06-19 | 2019-10-25 | 视联动力信息技术股份有限公司 | 一种数据传输方法和视联网服务器 |
CN110381028B (zh) * | 2019-06-19 | 2022-02-22 | 视联动力信息技术股份有限公司 | 一种数据传输方法和视联网服务器 |
WO2021232376A1 (zh) * | 2020-05-21 | 2021-11-25 | 华为技术有限公司 | 一种音频数据传输方法及相关装置 |
CN113449337A (zh) * | 2021-06-22 | 2021-09-28 | 广州市资拓科技有限公司 | 一种服务器托管信息处理方法及系统 |
Also Published As
Publication number | Publication date |
---|---|
CN110138513B (zh) | 2020-12-29 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN108012106B (zh) | 一种视联网监控资源同步的方法及系统 | |
CN108418778A (zh) | 一种互联网与视联网通信的方法、装置及交互系统 | |
CN109120962A (zh) | 软件终端连接视联网的方法和装置 | |
CN109120946A (zh) | 收看直播的方法和装置 | |
CN108616549A (zh) | 一种文件上传方法及文件服务器 | |
CN109996086A (zh) | 一种视联网业务状态查询方法及装置 | |
CN110474721A (zh) | 视频数据传输方法、装置及计算机可读存储介质 | |
CN108243343B (zh) | 一种基于视联网的点位分布统计方法及其服务器 | |
CN108307212B (zh) | 一种文件点播方法和装置 | |
CN108989078A (zh) | 一种视联网中节点设备故障检测方法和装置 | |
CN109246486A (zh) | 一种组帧方法和装置 | |
CN109996127A (zh) | 基于视联网的数据传输方法和装置 | |
CN110022295A (zh) | 一种数据传输的方法和视联网系统 | |
CN110062295A (zh) | 一种文件资源获取方法及系统 | |
CN109889779A (zh) | 一种报文乱序的处理方法和装置 | |
CN109547163A (zh) | 一种数据传输速率的控制方法和装置 | |
CN110166433A (zh) | 一种视频数据获取的方法和系统 | |
CN110049346A (zh) | 一种视频直播的方法和系统 | |
CN110049341A (zh) | 视频处理方法和装置 | |
CN108809922B (zh) | 一种音频故障处理方法、会议调度端和视联网终端 | |
CN109788369A (zh) | 终端控制方法和装置 | |
CN109151610A (zh) | 一种接收网络摄像机画面的处理方法和装置 | |
CN110138513A (zh) | 一种数据传输方法和视联网系统 | |
CN110266577A (zh) | 一种隧道建立方法和视联网系统 | |
CN110121075A (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 | ||
CP03 | Change of name, title or address |
Address after: 33rd Floor, No.1 Huasheng Road, Yuzhong District, Chongqing 400013 Patentee after: VISIONVERA INFORMATION TECHNOLOGY Co.,Ltd. Country or region after: China Address before: 100000 Beijing Dongcheng District Qinglong Hutong 1 Song Hua Building A1103-1113 Patentee before: VISIONVERA INFORMATION TECHNOLOGY Co.,Ltd. Country or region before: China |