CN113347137B - 数据流切片的补片方法、装置、计算机设备及存储介质 - Google Patents
数据流切片的补片方法、装置、计算机设备及存储介质 Download PDFInfo
- Publication number
- CN113347137B CN113347137B CN202010135865.4A CN202010135865A CN113347137B CN 113347137 B CN113347137 B CN 113347137B CN 202010135865 A CN202010135865 A CN 202010135865A CN 113347137 B CN113347137 B CN 113347137B
- Authority
- CN
- China
- Prior art keywords
- slice
- data stream
- node
- subscription
- patch
- 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
- 238000000034 method Methods 0.000 title claims abstract description 55
- 230000000153 supplemental effect Effects 0.000 claims abstract description 7
- 230000005540 biological transmission Effects 0.000 claims description 15
- 238000012216 screening Methods 0.000 claims description 14
- 238000004590 computer program Methods 0.000 claims description 6
- 238000010586 diagram Methods 0.000 description 7
- 230000003287 optical effect Effects 0.000 description 6
- 230000005856 abnormality Effects 0.000 description 5
- 238000012545 processing Methods 0.000 description 5
- 238000001514 detection method Methods 0.000 description 3
- 230000002093 peripheral effect Effects 0.000 description 3
- 230000006870 function Effects 0.000 description 2
- 239000013307 optical fiber Substances 0.000 description 2
- 230000000644 propagated effect Effects 0.000 description 2
- 238000003491 array Methods 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 238000004891 communication Methods 0.000 description 1
- 230000000295 complement effect Effects 0.000 description 1
- 238000012544 monitoring process Methods 0.000 description 1
- 230000008707 rearrangement Effects 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
- 230000001360 synchronised effect Effects 0.000 description 1
- 239000002699 waste material Substances 0.000 description 1
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/1066—Session management
- H04L65/1076—Screening of IP real time communications, e.g. spam over Internet telephony [SPIT]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/60—Network streaming of media packets
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
- H04L67/104—Peer-to-peer [P2P] networks
- H04L67/1074—Peer-to-peer [P2P] networks for supporting data block transmission mechanisms
- H04L67/1078—Resource delivery mechanisms
- H04L67/108—Resource delivery mechanisms characterised by resources being split in blocks or fragments
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Multimedia (AREA)
- Business, Economics & Management (AREA)
- General Business, Economics & Management (AREA)
- Information Transfer Between Computers (AREA)
Abstract
本发明实施例公开了一种数据流切片的补片方法、装置、计算机设备及存储介质。所述方法包括:在从原始设备获取数据流切片的过程中,如果检测到订阅调整条件,则从至少一个备选节点中筛选出订阅节点,并开始从所述订阅节点继续获取数据流切片;根据从所述原始设备和所述订阅节点分别获取的数据流切片之间的切片差异,构造补片请求发送至服务器;接收所述服务器针对所述补片请求反馈的补充切片。本发明实施例可以降低补片率,降低补片成本。
Description
技术领域
本发明实施例涉及网络领域,尤其涉及一种数据流切片的补片方法、装置、计算机设备及存储介质。
背景技术
在流数据传输的过程中,通常服务器会将流数据切割成大小相同的数据包,将每个数据包分别作为一个切片推送给用户节点。
在服务器将切片推送给用户节点的过程中,会出现切片丢失的情况,此时,用户需要向服务器请求数据流切片的补片,这需要花费大量的服务器流量。
发明内容
本发明实施例提供一种数据流切片的补片方法、装置、计算机设备及存储介质,可以降低补片率,降低补片成本。
第一方面,本发明实施例提供了一种数据流切片的补片方法,包括:
在从原始设备获取数据流切片的过程中,如果检测到订阅调整条件,则从至少一个备选节点中筛选出订阅节点,并开始从所述订阅节点继续获取数据流切片;
根据从所述原始设备和所述订阅节点分别获取的数据流切片之间的切片差异,构造补片请求发送至服务器;
接收所述服务器针对所述补片请求反馈的补充切片。
第二方面,本发明实施例还提供了一种数据流切片的补片装置,包括:
订阅节点选择模块,用于在从原始设备获取数据流切片的过程中,如果检测到订阅调整条件,则从至少一个备选节点中筛选出订阅节点,并开始从所述订阅节点继续获取数据流切片;
补片请求模块,用于根据从所述原始设备和所述订阅节点分别获取的数据流切片之间的切片差异,构造补片请求发送至服务器;
补片接收模块,用于接收所述服务器针对所述补片请求反馈的补充切片。
第三方面,本发明实施例还提供了一种计算机设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序所述处理器执行所述程序时实现如本发明实施例中任一所述的数据流切片的补片方法。
第四方面,本发明实施例还提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现如本发明实施例中任一所述的数据流切片的补片方法。
本发明实施例通过在从原始设备获取数据流切片的过程中,检测到需要补片时,从众多备选节点中筛选出订阅节点,继续获取新的数据流切片,并根据需要补充的切片构造补片请求,发送至服务器,以获取反馈的补充切片,从而实现获取完整的数据流切片,从更换到新的路径获取后续的数据流切片,解决了现有技术中只能通过向服务器请求缺失的切片,导致服务器流量耗费巨大的问题,可以减少降低补片率,降低补片成本。
附图说明
图1是本发明实施例中的一种数据流切片的补片方法的流程图;
图2a是本发明实施例二中的一种数据流切片的补片方法的流程图;
图2b是本发明实施例二中的应用场景的示意图;
图3是本发明实施例三中的一种数据流切片的补片装置的结构示意图;
图4是本发明实施例四中的一种计算机设备的结构示意图。
具体实施方式
下面结合附图和实施例对本发明作进一步的详细说明。可以理解的是,此处所描述的具体实施例仅仅用于解释本发明,而非对本发明的限定。另外还需要说明的是,为了便于描述,附图中仅示出了与本发明相关的部分而非全部结构。
实施例一
图1为本发明实施例一中的一种数据流切片的补片方法的流程图的示意图,本实施例可适用于在切片丢失时更换切片来源以及获取缺失的切片的情况,该方法可以由本发明实施例提供的数据流切片的补片装置来执行,该装置可采用软件和/或硬件的方式实现,并一般可集成计算机设备中,具体可以是终端设备。如图1所示,本实施例的方法具体包括:
S110,在从原始设备获取数据流切片的过程中,如果检测到订阅调整条件,则从至少一个备选节点中筛选出订阅节点,并开始从所述订阅节点继续获取数据流切片。
在网络中可以采用数据流的形式传输数据,通常可以将完整数据流切割成大小相同的数据包,本发明实施例中的数据流切片为一个数据包,其中,切割方式可以根据需要进行设定,对此,本发明实施例不做具体限制。数据流切割形成的数据流切片按照切割顺序,依次传输。此时,为了区分不同的数据流切片,可以对数据流切片进行标识,数据流切片的标识信息用于确定数据流切片的次序。
原始设备用于向本机设备发送数据流切片。本机设备和备选节点均为终端设备。原始设备可以是数据流切片的数据源,也可以是数据流切片的转发设备。
具体的,本机设备和备选节点形成点对点网络(Peer to Peer,P2P)。可选的,所述原始设备包括内容分发网络(Content Delivery Network,CDN)服务器或点对点网络节点。内容分发网络服务器用于将数据流切片分发至点对点网络节点中。原始设备可以是内容分发网络服务器,还可以是任意点对点网络节点。示例性的,数据流为直播数据流,可以包括直播视频流和/或直播音频流等。可选的,所述内容分发网络服务器用于接收直播服务器将直播流数据切割形成的切片并分发至点对点网络节点中。
通过结合CDN和P2P网络作为数据流切片分发的网络,可以降低网络开销,提高内容分发效率,在网络堵塞时有效引导数据流切片的传输,提高数据流切片的连续性和时效性。
订阅调整条件用于本机设备判断是否需要切换数据流切片的来源,也即是否需要切换订阅节点,并在该过程中,判断是否需要进行补片,实际上订阅调整条件用于判断在需要切换订阅节点的过程中判断是否需要进行补片。示例性的,可以在检测到原始设备发生异常(如网络异常:掉线等)或者发现有更优节点可以订阅时,确定需要进行切换订阅节点。当确定需要切换订阅节点且检测到需要进行补片时,确定满足订阅调整条件。
可选的,所述检测到订阅调整条件,包括:在订阅节点切换的过程中,当接收到的最新切片与接收到的上一切片满足不连续条件时,确定检测到订阅调整条件,并将所述上一切片作为所述从所述原始设备获取的最后一个连续数据流切片。
在订阅节点切换的过程中,表明本机设备正处于切换数据流切片的来源的过程中,或者是本机设备正处于切换订阅节点的过程中。当本机设备检测到自身发生异常,或者是检测到存在更优订阅节点时,本机设备进行订阅节点切换。异常检测可以通过本机设备的异常监控操作实现;更优节点的检测可以通过获取点对点网络中各备选节点的延迟和丢包率,计算各备选节点的节点质量,如果存在比原始设备的节点质量高的备选节点,确定存在更优节点。此外,还可以有其他确定订阅节点切换操作的方法,对此,本发明实施例不作具体限制。
本机设备从原始设备处依次获取多个数据流切片,不同数据流切片存在标识信息,标识信息可以是数据流切片的次序编号。可以理解的是,服务器下发的数据流切片是按照顺序依次下发数据流切片,如果由于某些原因(如网络断掉),某些数据流切片未发送到本机设备,从而本机设备接收到的数据流切片的次序编号不连续,由此,数据流切片的次序编号不连续可以作为需要补片的触发条件。
最新切片为本机设备从原始设备处获取的最新切片,上一切片为本机设备从原始设备处获取的最新切片的前一个切片。如果本机设备在接收上一切片和最新切片的过程中不存在缺失的切片,则上一切片和最新切片应该是次序相邻。
不连续条件用于判断上一切片和最新切片的次序是否相邻,其中,次序可以是指数据流切片从服务器发送的次序。补片条件用于判断上一切片和最新切片之间是否需要补片。具体的,当上一切片和最新切片的次序不相邻时,也即,上一切片和最新切片之间存在缺失的数据流切片,确定检测到订阅调整条件。此时,上一切片实际是从原始设备获取的最后一个连续数据流切片,而最新切片与前面获取的数据流切片均不连续。
示例性的,本机设备连续获取次序编号为1-10的数据流切片,而当前获取的数据流切片的次序编号为13,此时,最新切片的次序编号为13,上一切片的次序编号为10,由于10和13不连续,最新切片与上一切片满足不连续条件,确定检测到订阅调整条件。
通过判断最新切片与上一切片是否连续,来判断是否满足补片条件可以准确在本机设备存在补片需求时,进行补片,以及更换数据流切片的来源。
备选节点可以作为本机设备的订阅节点,本机设备可以通过订阅备选节点,来获取备选节点接收到的数据流切片。需要说明的是,本机设备仅能获取在订阅备选节点之后,备选节点接收到的数据流切片,而备选节点在被订阅之前获取的数据流切片,无法发送至本机设备。
备选节点存在多个,可以对订阅节点进行筛选,选择节点质量最好的节点作为订阅节点。本机设备建立与订阅节点之间的订阅关系之后,本机设备可以订阅订阅节点更新的数据流切片,从而获取订阅节点更新的数据流切片,也就是说,本机设备从原始设备获取数据流切片,切换为从订阅节点获取数据流切片。
可以理解的是,由于本机设备接收到的当前最新的数据流切片和订阅节点接收到的当前最新的数据流切片不同,例如,根据当前最新的数据流切片的次序,可以确定本机设备接收到的当前最新的数据流切片和订阅节点接收到的当前最新的数据流切片之间缺失的数据流切片,缺失的切片需要从服务器中请求获取。
S120,根据从所述原始设备和所述订阅节点分别获取的数据流切片之间的切片差异,构造补片请求发送至服务器。
切片差异用于确定本机设备接收到的当前最新的数据流切片和订阅节点接收到的当前最新的数据流切片之间缺失的数据流切片,以及用于生成补片请求发送。
补片请求用于服务器反馈待补充的数据流切片。
服务器用于发送数据流切片。可选的,所述服务器包括内容分发网络服务器。内容分发网络服务器用于接收数据源发送的数据流切片并分发至本机设备和备选节点等;或者内容分发网络服务器用于接收数据源发送的数据流,并进行切割形成数据流切片,分发至本机设备和备选节点等。
S130,接收所述服务器针对所述补片请求反馈的补充切片。
补充切片用于在本机设备接收到的当前最新的数据流切片和订阅节点接收到的当前最新的数据流切片之间进行填充,使本机设备接收到的数据流切片为连续的数据流切片。
本发明实施例通过在从原始设备获取数据流切片的过程中,检测到需要补片时,从众多备选节点中筛选出订阅节点,继续获取新的数据流切片,并根据需要补充的切片构造补片请求,发送至服务器,以获取反馈的补充切片,从而实现获取完整的数据流切片,从更换到新的路径获取后续的数据流切片,解决了现有技术中只能通过向服务器请求缺失的切片,导致服务器流量耗费巨大的问题,可以减少降低补片率,降低补片成本。
实施例二
图2a为本发明实施例二中的一种数据流切片的补片方法的流程图,本实施例以上述实施例为基础进行具体化。本实施例的方法具体包括:
S210,在从原始设备获取数据流切片的过程中,如果检测到订阅调整条件,则检测当前各所述备选节点获取的最后一个连续数据流切片,作为比对切片。
当前各所述备选节点获取的最后一个连续数据流切片可以是指,备选节点获取的多个连续数据流切片中最新的数据流切片。比对切片用于确定补片的数量。具体的,比对切片可以是指,在本机设备检测到补片需求时,其他备选节点已经接收到的连续的多个数据流切片中,最后的也即最新的数据流切片。
本发明实施例中的原始设备、数据流切片、订阅调整条件、备选节点、补片触发、服务器针、补片请求、补充切片和订阅节点等可以参考上述实施例的描述。
可选的,所述检测到订阅调整条件,包括:当接收到的最新切片与接收到的上一切片满足不连续条件时,确定检测到订阅调整条件,并将所述上一切片作为所述从所述原始设备获取的最后一个连续数据流切片。
S220,根据从所述原始设备获取的最后一个连续数据流切片,与各所述比对切片之间的相差的数据流切片数量,在各所述备选节点中筛选出订阅节点,并开始从所述订阅节点继续获取数据流切片。
原始设备获取的最后一个连续数据流切片可以是指原始设备获取的多个数据流切片中,连续的多个数据流切片中的最后接收到的数据流切片。
可以理解的是,由于网络差异,不同终端设备从服务器接收到的数据流切片的数量不同。也即,不同终端设备从服务器接收到的数据流切片存在差异。
数据流切片数量用于确定补片的数量。可以理解的是,数据流切片数量等于最后一个连续数据流切片与比对切片之间的差值,即为本机设备接收到的数据流切片与各备选节点接收到的数据流切片之间的缺失的数据流切片的数量,本机设备需要从服务器中获取的补片的数量。
在各备选节点中筛选出订阅节点,实际是筛选出需要从服务器获取的补片的数量较少且节点质量较好的节点。如果向服务器请求过多的补片,则需要耗费的服务器流量越多。
开始从订阅节点继续获取数据流切片,在订阅之后,订阅节点更新的数据流切片,可以同步更新到本机设备中。而订阅节点之前获取的数据流切片,无法同步到本机设备中,此时,本机设备只能从服务器中获取缺失的数据流切片。
可选的,所述根据从所述原始设备获取的最后一个连续数据流切片,与各所述比对切片之间的相差的数据流切片数量,在各所述备选节点中筛选出订阅节点,包括:计算从所述原始设备获取的最后一个连续数据流切片,与各所述比对切片之间的相差的数据流切片数量;将数据流切片数量小于等于预设补片数量的备选节点作为目标备选节点,所述补片数量根据切片传输速率和预设约束时间确定;根据节点质量参数从至少一个目标备选节点中筛选出订阅节点,所述节点质量参数包括延时和/或丢包率。
预设补片数量用于筛选目标备选节点。其中,目标备选节点获取的比对切片与原始设备获取的最后一个连续数据流切片之间的切片差值均小于预设补片数量。也即,原始设备将目标备选节点作为订阅节点,相应的,从服务器获取补片数量而产生的服务器流量较少,从而降低补片成本。
切片传输速率用于评估目标备选节点的数据流切片的传输速率;约束时间用于数据流切片的传输时长。通常,约束时间可以根据需要进行设定,例如可以设定4秒,对此,本发明实施例不做具体限制,可以根据实际情况进行设定。其中,若数据流为视频流:切片传输速率(片/s)=视频码率(每秒视频流量)/切片大小,示例性的,切片大小为1.2KB,观看视频码率为4M时可得到切片传输速率=4*1024*1024bit/(1.2*1024*8bit)=426片/s。其中,视频码率根据待传输的视频的质量(如分辨率)确定。切片大小通常由视频源确定。进一步的,若约束时间为4秒,预设补片数量=切片传输速率*约束时间=426片/s*4s=1704片。假设,从原始设备获取的最后一个连续数据流切片为10000,则相应的目标备选节点当前获取的最后一个连续数据流切片为11704片。
目标备选节点的数量为至少一个,如果目标备选节点为一个,则将目标备选节点作为订阅节点。如果目标备选节点为至少两个,则根据节点质量参数从中选出质量好的目标备选节点作为订阅节点。通常,节点质量由延时和/或丢包率确定。延时用于评估数据发送方到数据接收方的时长,丢包率用于评估单位时间内数据发送方将多个数据包发送至数据接收方的过程中,未被数据接收方接收到的数量。
通过根据需要从服务器中获取补片的数量在设定范围内以及节点质量确定订阅节点,可以将切片范围差距较小的终端设备聚集在一起,降低切片差距过大带来的过多的服务器流量,从而降低带宽成本,可以兼顾减少从服务器处获取切片的数量,同时从订阅节点稳定快速获取切片,也即在保证减少服务器流量消耗的同时,保证后续数据流切片的传输的稳定性。
此外,预设补片数量可以替换为补片数量范围,也即将数据流切片数量属于补片数量范围的备选节点作为目标备选节点,补片数量范围根据切片传输速率和预设约束时间确定。对此,本发明实施例不做具体限制,可以根据实际情况确定。
S230,根据从所述原始设备和所述订阅节点分别获取的数据流切片之间的切片差异,构造补片请求发送至服务器。
可选的,所述根据从所述原始设备和所述订阅节点分别获取的数据流切片之间的切片差异,构造补片请求发送至服务器,包括:根据所述原始设备获取的最后一个连续数据流切片,确定补片区间下限;根据与所述订阅节点对应的比对切片,确定补片区间上限;根据所述补片区间下限和所述补片区间上限,构造补片请求发送至服务器。
原始设备获取的最后一个连续数据流切片,确定补片区间下限,表明补片区间下限为原始设备可获取的最后一个的数据流切片,且该数据流切片与之前的数据流切片是连续的。补片区间下限加1作为补片区间的最小的次序编号。
比对切片,确定补片区间上限,表明补片区间上限为原始设备从订阅节点处可获取的首个数据流切片的上一个数据流切片,且该数据流切片与之前的数据流切片是连续的。补片区间上限作为补片区间的最大的次序编号。
根据补片区间下限和补片区间上限,形成补片区间,补片区间中的全部数据流切片为需要从服务器获取的补充切片。
通过分别确定补片区间下限和补片区间上限,可以确定补片区间,从而准确确定需要补充的数据流切片,进而精准获取缺失的补片,并减少服务器流量的浪费,降低补片成本。
在一个具体的例子中,如图2b,在数据流切片的传输应用场景中,图中数字为各节点当前接收到的最后一个连续数据流切片的次序编号。当本机设备订阅成功时,订阅节点从最新数据流切片开始传输给本机设备,补片数量=订阅节点的最后一个连续数据流切片-本机设备最后一个连续数据流切片。内容分发网络服务器中心从数据流服务器获取完整的数据流切片,共100个。内容分发网络服务器中心向下分发内容分发网络服务器,最终分发到点对点网络中,而且,在传输过程中数据流切片有丢失情况。点对点网络中各节点可以互相订阅。
示例性的,点对点网络节点d寻找订阅时,点对点网络节点a、点对点网络节点b、点对点网络节点c,皆满足延时与丢包率条件,且节点质量c>a>b。如果存在补片数量范围约束,d优先选择c订阅,将产生补片数量20。如果d的补片数量范围为65至75,这时d会选择b订阅,此时只需要向内容分发网络服务器请求10个补充切片。
S240,接收所述服务器针对所述补片请求反馈的补充切片。
补充切片具体可以是指原始设备获取的最后一个连续数据流切片与当前各所述备选节点获取的最后一个连续数据流切片之间的数据流切片。
可选的,所述原始设备包括内容分发网络服务器或点对点网络节点,所述服务器包括内容分发网络服务器。
可选的,所述内容分发网络服务器用于接收直播服务器将直播流数据切割形成的切片并分发至点对点网络节点中。
本发明实施例通过根据各备选节点获取的最后一个连续数据流切片,以及本机设备获取的最后一个连续数据流切片,可以确定本机设备与各备选节点获取的数据流切片之间的切片差异,由此确定每个备选节点对应的补片数量,从而筛选出订阅节点,实现灵活确定订阅节点。
实施例三
图3为本发明实施例三中的一种数据流切片的补片装置的示意图。实施例三是实现本发明上述实施例提供的数据流切片的补片方法的相应装置,该装置可采用软件和/或硬件的方式实现,并一般可集成计算机设备中。
相应的,本实施例的装置可以包括:
订阅节点选择模块310,用于在从原始设备获取数据流切片的过程中,如果检测到订阅调整条件,则从至少一个备选节点中筛选出订阅节点,并开始从所述订阅节点继续获取数据流切片;
补片请求模块320,用于根据从所述原始设备和所述订阅节点分别获取的数据流切片之间的切片差异,构造补片请求发送至服务器;
补片接收模块330,用于接收所述服务器针对所述补片请求反馈的补充切片。
本发明实施例通过在从原始设备获取数据流切片的过程中,检测到需要补片时,从众多备选节点中筛选出订阅节点,继续获取新的数据流切片,并根据需要补充的切片构造补片请求,发送至服务器,以获取反馈的补充切片,从而实现获取完整的数据流切片,从更换到新的路径获取后续的数据流切片,解决了现有技术中只能通过向服务器请求缺失的切片,导致服务器流量耗费巨大的问题,可以减少降低补片率,降低补片成本。
进一步的,所述订阅节点选择模块310,包括:数据流切片数量差获取单元,用于检测当前各所述备选节点获取的最后一个连续数据流切片,作为比对切片;根据从所述原始设备获取的最后一个连续数据流切片,与各所述比对切片之间的相差的数据流切片数量,在各所述备选节点中筛选出订阅节点。
进一步的,进一步的,所述数据流切片数量差获取单元,包括:补片数量范围约束子单元,用于计算从所述原始设备获取的最后一个连续数据流切片,与各所述比对切片之间的相差的数据流切片数量;将数据流切片数量小于等于预设补片数量的备选节点作为目标备选节点,所述补片数量根据切片传输速率和预设约束时间确定;根据节点质量参数从至少一个目标备选节点中筛选出订阅节点,所述节点质量参数包括延时和/或丢包率。
进一步的,所述补片请求模块320,包括:补片区间确定单元,用于根据所述原始设备获取的最后一个连续数据流切片,确定补片区间下限;根据与所述订阅节点对应的比对切片,确定补片区间上限;根据所述补片区间下限和所述补片区间上限,构造补片请求发送至服务器。
进一步的,所述订阅节点选择模块310,包括:订阅调整条件检测单元,用于当接收到的最新切片与接收到的上一切片满足不连续条件时,确定检测到订阅调整条件,并将所述上一切片作为所述从所述原始设备获取的最后一个连续数据流切片。
进一步的,所述原始设备包括内容分发网络服务器或点对点网络节点,所述服务器包括内容分发网络服务器。
进一步的,所述内容分发网络服务器用于接收直播服务器将直播流数据切割形成的切片并分发至点对点网络节点中。
上述装置可执行本发明实施例所提供的方法,具备执行方法相应的功能模块和有益效果。
实施例四
图4为本发明实施例四提供的一种计算机设备的结构示意图。图4示出了适于用来实现本发明实施方式的示例性计算机设备12的框图。图4显示的计算机设备12仅仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
如图4所示,计算机设备12以通用计算设备的形式表现。计算机设备12的组件可以包括但不限于:一个或者多个处理器或者处理单元16,系统存储器28,连接不同系统组件(包括系统存储器28和处理单元16)的总线18。计算机设备12可以是挂接在总线上的设备。
总线18表示几类总线结构中的一种或多种,包括存储器总线或者存储器控制器,外围总线,图形加速端口,处理器或者使用多种总线结构中的任意总线结构的局域总线。举例来说,这些体系结构包括但不限于工业标准体系结构(Industry StandardArchitecture,ISA)总线,微通道体系结构(Micro Channel Architecture,MCA)总线,增强型ISA总线、视频电子标准协会(Video Electronics Standards Association,VESA)局域总线以及外围组件互连(PerIPheral Component Interconnect,PCI)总线。
计算机设备12典型地包括多种计算机系统可读介质。这些介质可以是任何能够被计算机设备12访问的可用介质,包括易失性和非易失性介质,可移动的和不可移动的介质。
系统存储器28可以包括易失性存储器形式的计算机系统可读介质,例如随机存取存储器(RAM)30和/或高速缓存存储器32。计算机设备12可以进一步包括其它可移动/不可移动的、易失性/非易失性计算机系统存储介质。仅作为举例,存储系统34可以用于读写不可移动的、非易失性磁介质(图4未显示,通常称为“硬盘驱动器”)。尽管图4中未示出,可以提供用于对可移动非易失性磁盘(例如“软盘”)读写的磁盘驱动器,以及对可移动非易失性光盘(例如紧凑磁盘只读存储器(Compact Disc Read-Only Memory,CD-ROM),数字视盘(Digital Video Disc-Read Only Memory,DVD-ROM)或者其它光介质)读写的光盘驱动器。在这些情况下,每个驱动器可以通过一个或者多个数据介质接口与总线18相连。系统存储器28可以包括至少一个程序产品,该程序产品具有一组(例如至少一个)程序模块,这些程序模块被配置以执行本发明各实施例的功能。
具有一组(至少一个)程序模块42的程序/实用工具40,可以存储在例如系统存储器28中,这样的程序模块42包括但不限于操作系统、一个或者多个应用程序、其它程序模块以及程序数据,这些示例中的每一个或某种组合中可能包括网络环境的实现。程序模块42通常执行本发明所描述的实施例中的功能和/或方法。
计算机设备12也可以与一个或多个外部设备14(例如键盘、指向设备、显示器24等)通信,还可与一个或者多个使得用户能与该计算机设备12交互的设备通信,和/或与使得该计算机设备12能与一个或多个其它计算设备进行通信的任何设备(例如网卡,调制解调器等等)通信。这种通信可以通过输入/输出(Input/Output,I/O)接口22进行。并且,计算机设备12还可以通过网络适配器20与一个或者多个网络(例如局域网(Local AreaNetwork,LAN),广域网(Wide Area Network,WAN)通信。如图所示,网络适配器20通过总线18与计算机设备12的其它模块通信。应当明白,尽管图4中未示出,可以结合计算机设备12使用其它硬件和/或软件模块,包括但不限于:微代码、设备驱动器、冗余处理单元、外部磁盘驱动阵列(Redundant Arrays of Inexpensive Disks,RAID)系统、磁带驱动器以及数据备份存储系统等。
处理单元16通过运行存储在系统存储器28中的程序,从而执行各种功能应用以及数据处理,例如实现本发明任意实施例所提供的方法。
实施例五
本发明实施例五提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现如本申请所有发明实施例提供的数据流切片的补片方法:
也即,该程序被处理器执行时实现:在从原始设备获取数据流切片的过程中,如果检测到订阅调整条件,则从至少一个备选节点中筛选出订阅节点,并开始从所述订阅节点继续获取数据流切片;根据从所述原始设备和所述订阅节点分别获取的数据流切片之间的切片差异,构造补片请求发送至服务器;接收所述服务器针对所述补片请求反馈的补充切片。
本发明实施例的计算机存储介质,可以采用一个或多个计算机可读的介质的任意组合。计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、RAM、只读存储器(Read OnlyMemory,ROM)、可擦式可编程只读存储器(Erasable Programmable Read Only Memory,EPROM)、闪存、光纤、便携式CD-ROM、光存储器件、磁存储器件、或者上述的任意合适的组合。在本文件中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。
计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括——但不限于——电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。
计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括——但不限于——无线、电线、光缆、无线电频率(RadioFrequency,RF)等等,或者上述的任意合适的组合。
可以以一种或多种程序设计语言或其组合来编写用于执行本发明操作的计算机程序代码,所述程序设计语言包括面向对象的程序设计语言—诸如Java、Smalltalk、C++,还包括常规的过程式程序设计语言—诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络——包括LAN或WAN——连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。
注意,上述仅为本发明的较佳实施例及所运用技术原理。本领域技术人员会理解,本发明不限于这里所述的特定实施例,对本领域技术人员来说能够进行各种明显的变化、重新调整和替代而不会脱离本发明的保护范围。因此,虽然通过以上实施例对本发明进行了较为详细的说明,但是本发明不仅仅限于以上实施例,在不脱离本发明构思的情况下,还可以包括更多其他等效实施例,而本发明的范围由所附的权利要求范围决定。
Claims (9)
1.一种数据流切片的补片方法,其特征在于,包括:
在从原始设备获取数据流切片的过程中,如果检测到订阅调整条件,则从至少一个备选节点中筛选出订阅节点,并开始从所述订阅节点继续获取数据流切片;
根据从所述原始设备和所述订阅节点分别获取的数据流切片之间的切片差异,构造补片请求发送至服务器;
接收所述服务器针对所述补片请求反馈的补充切片;
所述从至少一个备选节点中筛选出订阅节点,包括:
检测当前各所述备选节点获取的最后一个连续数据流切片,作为比对切片;
根据从所述原始设备获取的最后一个连续数据流切片,与各所述比对切片之间的相差的数据流切片数量,在各所述备选节点中筛选出订阅节点。
2.根据权利要求1所述的方法,其特征在于,所述根据从所述原始设备获取的最后一个连续数据流切片,与各所述比对切片之间的相差的数据流切片数量,在各所述备选节点中筛选出订阅节点,包括:
计算从所述原始设备获取的最后一个连续数据流切片,与各所述比对切片之间的相差的数据流切片数量;
将数据流切片数量小于等于预设补片数量的备选节点作为目标备选节点,所述补片数量根据切片传输速率和预设约束时间确定;
根据节点质量参数从至少一个目标备选节点中筛选出订阅节点,所述节点质量参数包括延时和/或丢包率。
3.根据权利要求1所述的方法,其特征在于,所述根据从所述原始设备和所述订阅节点分别获取的数据流切片之间的切片差异,构造补片请求发送至服务器,包括:
根据所述原始设备获取的最后一个连续数据流切片,确定补片区间下限;
根据与所述订阅节点对应的比对切片,确定补片区间上限;
根据所述补片区间下限和所述补片区间上限,构造补片请求发送至服务器。
4.根据权利要求1所述的方法,其特征在于,所述检测到订阅调整条件,包括:
在订阅节点切换的过程中,当接收到的最新切片与接收到的上一切片满足不连续条件时,确定检测到订阅调整条件,并将所述上一切片作为所述从所述原始设备获取的最后一个连续数据流切片。
5.根据权利要求1所述的方法,其特征在于,所述原始设备包括内容分发网络服务器或点对点网络节点,所述服务器包括内容分发网络服务器。
6.根据权利要求5所述的方法,其特征在于,所述内容分发网络服务器用于接收直播服务器将直播流数据切割形成的切片并分发至点对点网络节点中。
7.一种数据流切片的补片装置,其特征在于,包括:
订阅节点选择模块,用于在从原始设备获取数据流切片的过程中,如果检测到订阅调整条件,则从至少一个备选节点中筛选出订阅节点,并开始从所述订阅节点继续获取数据流切片;
补片请求模块,用于根据从所述原始设备和所述订阅节点分别获取的数据流切片之间的切片差异,构造补片请求发送至服务器;
补片接收模块,用于接收所述服务器针对所述补片请求反馈的补充切片;
所述订阅节点选择模块,包括:数据流切片数量差获取单元,用于检测当前各所述备选节点获取的最后一个连续数据流切片,作为比对切片;
根据从所述原始设备获取的最后一个连续数据流切片,与各所述比对切片之间的相差的数据流切片数量,在各所述备选节点中筛选出订阅节点。
8.一种计算机设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,其特征在于,所述处理器执行所述程序时实现如权利要求1-6中任一所述的数据流切片的补片方法。
9.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现如权利要求1-6中任一所述的数据流切片的补片方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010135865.4A CN113347137B (zh) | 2020-03-02 | 2020-03-02 | 数据流切片的补片方法、装置、计算机设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010135865.4A CN113347137B (zh) | 2020-03-02 | 2020-03-02 | 数据流切片的补片方法、装置、计算机设备及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN113347137A CN113347137A (zh) | 2021-09-03 |
CN113347137B true CN113347137B (zh) | 2024-03-05 |
Family
ID=77467257
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202010135865.4A Active CN113347137B (zh) | 2020-03-02 | 2020-03-02 | 数据流切片的补片方法、装置、计算机设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN113347137B (zh) |
Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102130778A (zh) * | 2010-10-22 | 2011-07-20 | 华为技术有限公司 | 一种iptv组播业务保护方法及系统 |
CN107277013A (zh) * | 2017-06-19 | 2017-10-20 | 网宿科技股份有限公司 | 对等网络中的直播系统及节点管理方法 |
CN108111531A (zh) * | 2018-01-02 | 2018-06-01 | 青岛海信网络科技股份有限公司 | 一种增强视频直播质量的方法及装置 |
CN108156473A (zh) * | 2017-12-28 | 2018-06-12 | 网宿科技股份有限公司 | 一种获取直播数据的方法及系统 |
CN108462755A (zh) * | 2018-03-28 | 2018-08-28 | 网宿科技股份有限公司 | 一种下载数据资源的方法和系统 |
CN109348243A (zh) * | 2018-11-14 | 2019-02-15 | 广州虎牙信息科技有限公司 | 订阅处理的方法、装置及直播系统 |
CN110022500A (zh) * | 2019-04-02 | 2019-07-16 | 视联动力信息技术股份有限公司 | 一种丢包处理方法和装置 |
CN110166834A (zh) * | 2018-02-11 | 2019-08-23 | 腾讯科技(深圳)有限公司 | 一种数据播放方法、装置及存储介质 |
CN110365771A (zh) * | 2019-07-16 | 2019-10-22 | 深圳市网心科技有限公司 | 一种数据获取方法、装置、系统和计算机可读存储介质 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20170288816A1 (en) * | 2016-03-30 | 2017-10-05 | Le Holdings (Beijing) Co., Ltd. | Method and system for compensating hls slice loss |
-
2020
- 2020-03-02 CN CN202010135865.4A patent/CN113347137B/zh active Active
Patent Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102130778A (zh) * | 2010-10-22 | 2011-07-20 | 华为技术有限公司 | 一种iptv组播业务保护方法及系统 |
CN107277013A (zh) * | 2017-06-19 | 2017-10-20 | 网宿科技股份有限公司 | 对等网络中的直播系统及节点管理方法 |
CN108156473A (zh) * | 2017-12-28 | 2018-06-12 | 网宿科技股份有限公司 | 一种获取直播数据的方法及系统 |
CN108111531A (zh) * | 2018-01-02 | 2018-06-01 | 青岛海信网络科技股份有限公司 | 一种增强视频直播质量的方法及装置 |
CN110166834A (zh) * | 2018-02-11 | 2019-08-23 | 腾讯科技(深圳)有限公司 | 一种数据播放方法、装置及存储介质 |
CN108462755A (zh) * | 2018-03-28 | 2018-08-28 | 网宿科技股份有限公司 | 一种下载数据资源的方法和系统 |
CN109348243A (zh) * | 2018-11-14 | 2019-02-15 | 广州虎牙信息科技有限公司 | 订阅处理的方法、装置及直播系统 |
CN110022500A (zh) * | 2019-04-02 | 2019-07-16 | 视联动力信息技术股份有限公司 | 一种丢包处理方法和装置 |
CN110365771A (zh) * | 2019-07-16 | 2019-10-22 | 深圳市网心科技有限公司 | 一种数据获取方法、装置、系统和计算机可读存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN113347137A (zh) | 2021-09-03 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN111800443B (zh) | 数据处理系统和方法、装置以及电子设备 | |
US9173006B2 (en) | Method for live broadcasting in a distributed network and apparatus for the same | |
WO2007012914A1 (en) | Distributed system for delivery of information via a digital network | |
CN108712422B (zh) | 一种创建转码任务的方法和装置 | |
EP3497909B1 (en) | Improved adaptive bit rate streaming of live content with manifest update push notification or long poll | |
CN103945198A (zh) | 一种控制视频监控系统流媒体路由的系统和方法 | |
CN111404882B (zh) | 媒体流处理方法及装置 | |
JP2017525213A (ja) | 効率的なピア支援ストリーミングのためのキャッシュマニフェスト | |
CN112311874B (zh) | 媒体数据处理方法、装置、存储介质及电子设备 | |
CN113572750B (zh) | 视频数据传输方法及装置 | |
CN112737897A (zh) | 一种链路监测调度方法、装置、设备及存储介质 | |
US20120072604A1 (en) | technique for delivering content to a user | |
US8910226B2 (en) | Transmitting apparatus, transmitting method, receiving apparatus, receiving method, program, and content distribution system | |
CN118018472A (zh) | 一种数据传输处理方法、装置、存储介质及电子装置 | |
CN114222086B (zh) | 音视频码流的调度方法、系统、介质及电子装置 | |
CN101924777B (zh) | 在p2p流媒体系统中查找活动节点的方法、系统及设备 | |
CN112969202B (zh) | 一种网络参数调整方法、装置、电子设备及存储介质 | |
CN108632680B (zh) | 一种直播内容的调度方法、调度服务器及终端 | |
CN113347137B (zh) | 数据流切片的补片方法、装置、计算机设备及存储介质 | |
JP4398843B2 (ja) | 配信サーバ及び配信プログラム | |
CN113347138B (zh) | 转码数据流的传输方法、装置、计算机设备及存储介质 | |
CN110247847B (zh) | 节点之间回源选路的方法和装置 | |
CN111835801A (zh) | 文件下载方法、装置、服务器、边缘设备、终端及介质 | |
CN114077409A (zh) | 投屏方法及装置、电子设备和计算机可读介质 | |
US20190036838A1 (en) | Delivery of Multimedia Components According to User Activity |
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 |