CN112073747A - 一种流媒体数据预览方法、用户端设备及中继服务器 - Google Patents
一种流媒体数据预览方法、用户端设备及中继服务器 Download PDFInfo
- Publication number
- CN112073747A CN112073747A CN202010988958.1A CN202010988958A CN112073747A CN 112073747 A CN112073747 A CN 112073747A CN 202010988958 A CN202010988958 A CN 202010988958A CN 112073747 A CN112073747 A CN 112073747A
- Authority
- CN
- China
- Prior art keywords
- preview
- media data
- streaming media
- relay server
- connection
- 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.)
- Pending
Links
- 238000000034 method Methods 0.000 title claims abstract description 64
- 238000004590 computer program Methods 0.000 claims description 29
- 230000004044 response Effects 0.000 claims description 11
- 238000012545 processing Methods 0.000 description 29
- 230000006870 function Effects 0.000 description 11
- 238000010586 diagram Methods 0.000 description 10
- 230000008569 process Effects 0.000 description 6
- 238000005516 engineering process Methods 0.000 description 4
- 238000012544 monitoring process Methods 0.000 description 4
- 230000008878 coupling Effects 0.000 description 3
- 238000010168 coupling process Methods 0.000 description 3
- 238000005859 coupling reaction Methods 0.000 description 3
- 230000007246 mechanism Effects 0.000 description 3
- 230000005540 biological transmission Effects 0.000 description 2
- 238000004891 communication Methods 0.000 description 2
- 230000001815 facial effect Effects 0.000 description 2
- 230000002035 prolonged effect Effects 0.000 description 2
- 238000013461 design Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
- 230000004083 survival effect Effects 0.000 description 1
- 230000001960 triggered effect Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/20—Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
- H04N21/23—Processing of content or additional data; Elementary server operations; Server middleware
- H04N21/231—Content storage operation, e.g. caching movies for short term storage, replicating data over plural servers, prioritizing data for deletion
- H04N21/23106—Content storage operation, e.g. caching movies for short term storage, replicating data over plural servers, prioritizing data for deletion involving caching operations
-
- 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/1069—Session establishment or de-establishment
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/20—Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
- H04N21/23—Processing of content or additional data; Elementary server operations; Server middleware
- H04N21/239—Interfacing the upstream path of the transmission network, e.g. prioritizing client content requests
- H04N21/2393—Interfacing the upstream path of the transmission network, e.g. prioritizing client content requests involving handling client requests
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/40—Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
- H04N21/43—Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
- H04N21/437—Interfacing the upstream path of the transmission network, e.g. for transmitting client requests to a VOD server
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Business, Economics & Management (AREA)
- General Business, Economics & Management (AREA)
- Computer Networks & Wireless Communication (AREA)
- Information Transfer Between Computers (AREA)
Abstract
本申请适用于流媒体数据预览技术领域,提供了一种流媒体数据预览方法、用户端设备及中继服务器。在本申请的流媒体数据预览方法中,当用户端设备检测到用户登录成功时,用户端设备与中继服务器建立第一连接,并发送预推流指令至预览设备,指示预览设备与中继服务器建立第二连接以及预先推送实时流媒体数据至中继服务器。由于预览设备预先与中继服务器建立了第二连接,并且预先推送了实时流媒体数据至中继服务器,因此,当用户端设备发送预览请求至中继服务器时,中继服务器无需与预览设备建立连接和等待预览设备推送流媒体数据。中继服务器可以快速地从缓存中获取并反馈目标流媒体数据至用户端设备,减少了用户等待预览的时间,提升了用户的体验。
Description
技术领域
本申请属于流媒体数据预览技术领域,尤其涉及一种流媒体数据预览方法、用户端设备及中继服务器。
背景技术
流媒体技术是一种从网络上获取音频和视频等连续多媒体数据内容的流式传输技术。通过用户端设备远程进行视频监控预览,也属于流媒体实时传输中的一种,用户端进行预览操作之后,想要在远程观看到实时监控视频,需要等待一段时间直到用户端设备播放出视频画面。
现有的流媒体数据预览方法中,用户端设备进行预览操作后,立即通知相应预览设备推送流媒体数据到中继流媒体服务器,与此同时用户端设备从中继流媒体服务器拉流,这样就可以按照用户端的需求进行预览。但是,这种流媒体数据预览方法用户端设备需要等待较长时间才能进行预览,用户体验差。
发明内容
本申请实施例提供了一种流媒体数据预览方法、用户端设备及中继服务器,可以解决现有的流媒体数据预览方法用户端设备需要等待较长时间才能进行预览,用户体验差的问题。
第一方面,本申请实施例提供了一种流媒体数据预览方法,应用于用户端设备,所述方法包括:
当检测到用户登录成功时,发送第一连接请求至所述中继服务器,与所述中继服务器建立第一连接,以及,发送预推流指令至预览设备;所述预推流指令用于指示所述预览设备发送第二连接请求至所述中继服务器,与所述中继服务器建立第二连接,并通过所述第二连接将实时流媒体数据推送至所述中继服务器进行缓存;
当检测到预览请求时,发送预览请求至所述中继服务器;
接收所述中继服务器通过所述第一连接返回的目标流媒体数据;所述目标流媒体数据为与所述预览请求对应的预览设备的实时流媒体数据。
进一步地,在所述发送预推流指令至预览设备之前,包括:
显示设备列表;所述设备列表包括至少一台候选设备的信息;
响应于用户对所述设备列表的选择操作,从所述候选设备中确定预览设备。
进一步地,在所述发送预推流指令至预览设备之后,还包括:
周期性地发送心跳请求至所述中继服务器;
接收所述中继服务器返回的预览设备推送信息;
若所述预览设备推送信息为停止推送信息,则发送所述预推流指令至所述预览设备。
进一步地,所述预览设备的数量为一个或者多个。
第二方面,本申请实施例提供了一种流媒体数据预览方法,应用于中继服务器,所述方法包括:
当接收到用户端设备发送的第一连接请求时,与所述用户端设备建立第一连接;
当接收到预览设备发送的第二连接请求时,与所述预览设备建立第二连接;
接收所述预览设备通过所述第二连接推送的实时流媒体数据,并将所述实时流媒体数据存储至缓存区域;
当接收到所述用户端设备发送的预览请求时,将所述缓存区域中的目标流媒体数据通过所述第一连接发送至所述用户端设备;所述目标流媒体数据为与所述预览请求对应的预览设备的实时流媒体数据。
进一步地,在所述与所述预览设备建立第二连接之后,还包括:
若在预设时长内未接收到所述用户端设备发送的预览请求,则断开所述第二连接。
进一步地,在所述接收所述预览设备推送的实时流媒体数据,并将所述实时流媒体数据存储至缓存区域之后,还包括:
当接收到所述预览设备发送的新的实时流媒体数据时,删除所述缓存区域中所述预览设备对应的实时流媒体数据,将所述预览设备发送的新的实时流媒体数据存储至所述缓存区域。
第三方面,本申请实施例提供了一种用户端设备,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现如上述第一方面所述的流媒体数据预览方法。
第四方面,本申请实施例提供了一种中继服务器,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现如上述第二方面所述的流媒体数据预览方法。
第五方面,一种流媒体数据预览系统,包括用户端设备、中继服务器、预览设备;
所述用户端设备,用于当检测到用户登录成功时,发送第一连接请求至所述中继服务器,与所述中继服务器建立第一连接,以及,发送预推流指令至预览设备;所述预推流指令用于指示所述预览设备发送第二连接请求至所述中继服务器,与所述中继服务器建立第二连接,并通过所述第二连接将实时流媒体数据推送至所述中继服务器进行缓存;当检测到预览请求时,发送预览请求至所述中继服务器;接收所述中继服务器通过所述第一连接返回的目标流媒体数据;所述目标流媒体数据为与所述预览请求对应的预览设备的实时流媒体数据;
所述中继服务器,用于当接收到用户端设备发送的第一连接请求时,与所述用户端设备建立第一连接;
当接收到预览设备发送的第二连接请求时,与所述预览设备建立第二连接;
接收所述预览设备通过所述第二连接推送的实时流媒体数据,并将所述实时流媒体数据存储至缓存区域;
当接收到所述用户端设备发送的预览请求时,将所述缓存区域中的目标视流媒体数据通过所述第一连接发送至所述用户端设备;所述目标流媒体数据为与所述预览请求对应的预览设备的实时流媒体数据;
所述预览设备,用于当接收预推流指令时,发送第二连接请求至所述中继服务器,与所述中继服务器建立第二连接,并通过所述第二连接将实时流媒体数据推送至所述中继服务器。
本申请实施例中,用户端设备当检测到用户登录成功时,发送第一连接请求至所述中继服务器,与所述中继服务器建立第一连接,以及,发送预推流指令至预览设备;当检测到预览请求时,发送预览请求至所述中继服务器;接收所述中继服务器通过所述第一连接返回的目标流媒体数据,并且播放所述目标流媒体数据。上述方案,用户端设备在用户登录成功、但未进行流媒体数据预览的时候,就与中继服务器建立连接,但不拉流;与此同时用户端设备通知预览设备与中继服务器建立连接。这样提前建立用户端设备与中继服务器的连接,预览设备与中继服务器的连接,用户端设备不需要等待较长时间就可以进行预览,减少了时间的消耗,提升了用户的体验。
另一方面,中继服务器当接收到用户端设备发送的第一连接请求时,与所述用户端设备建立第一连接;当接收到预览设备发送的第二连接请求时,与所述预览设备建立第二连接;接收所述预览设备通过所述第二连接推送的实时流媒体数据,并将所述实时流媒体数据存储至缓存区域;当接收到所述用户端设备发送的预览请求时,将所述缓存区域中的目标流媒体数据通过所述第一连接发送至所述用户端设备。上述方案,中继服务器在用户登录成功、但未进行流媒体数据预览的时候,就与用户端设备建立连接,但用户端设备不拉流;与此同时,根据用户端设备的通知,与预览设备建立连接。这样提前建立用户端设备与中继服务器的连接,预览设备与中继服务器的连接,用户端设备不需要等待较长时间就可以进行预览,减少了时间的消耗,提升了用户的体验。
附图说明
为了更清楚地说明本申请实施例中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
图1为本申请第一实施例提供的一种流媒体数据预览系统的示意图;
图2是本申请第二实施例提供的一种流媒体数据预览方法的示意流程图;
图3是本申请第二实施例提供的一种流媒体数据预览方法中S104~S105的示意流程图;
图4是本申请第二实施例提供的一种流媒体数据预览方法中S106~S108的示意流程图;
图5是本申请第二实施例提供的一种流媒体数据预览方法的示意流程图;
图6是本申请第三实施例提供的用户端设备的示意图;
图7是本申请第四实施例提供的中继服务器的示意图;
图8是本申请第五实施例提供的用户端设备的示意图;
图9是本申请第六实施例提供的中继服务器的示意图。
具体实施方式
以下描述中,为了说明而不是为了限定,提出了诸如特定系统结构、技术之类的具体细节,以便透彻理解本申请实施例。然而,本领域的技术人员应当清楚,在没有这些具体细节的其它实施例中也可以实现本申请。在其它情况中,省略对众所周知的系统、装置、电路以及方法的详细说明,以免不必要的细节妨碍本申请的描述。
应当理解,当在本申请说明书和所附权利要求书中使用时,术语“包括”指示所描述特征、整体、步骤、操作、元素和/或组件的存在,但并不排除一个或多个其它特征、整体、步骤、操作、元素、组件和/或其集合的存在或添加。
还应当理解,在本申请说明书和所附权利要求书中使用的术语“和/或”是指相关联列出的项中的一个或多个的任何组合以及所有可能组合,并且包括这些组合。
如在本申请说明书和所附权利要求书中所使用的那样,术语“如果”可以依据上下文被解释为“当...时”或“一旦”或“响应于确定”或“响应于检测到”。类似地,短语“如果确定”或“如果检测到[所描述条件或事件]”可以依据上下文被解释为意指“一旦确定”或“响应于确定”或“一旦检测到[所描述条件或事件]”或“响应于检测到[所描述条件或事件]”。
另外,在本申请说明书和所附权利要求书的描述中,术语“第一”、“第二”、“第三”等仅用于区分描述,而不能理解为指示或暗示相对重要性。
在本申请说明书中描述的参考“一个实施例”或“一些实施例”等意味着在本申请的一个或多个实施例中包括结合该实施例描述的特定特征、结构或特点。由此,在本说明书中的不同之处出现的语句“在一个实施例中”、“在一些实施例中”、“在其他一些实施例中”、“在另外一些实施例中”等不是必然都参考相同的实施例,而是意味着“一个或多个但不是所有的实施例”,除非是以其他方式另外特别强调。术语“包括”、“包含”、“具有”及它们的变形都意味着“包括但不限于”,除非是以其他方式另外特别强调。
流媒体技术是一种从网络上获取音频和视频等连续多媒体数据内容的流式传输技术。通过客户端远程进行视频监控预览,也属于流媒体实时传输中的一种,而实时视频预览不可避免地就会涉及播放延迟的问题,即客户端进行预览操作之后,想要在远程观看到实时监控视频,就需要等待一段时间直到客户端播放出视频画面。
现有技术中,常用的预览方法为用户端设备进行某台预览设备预览操作后,立即通知相应预览设备推流到中继服务器,与此同时用户端设备从中继服务器拉流,这样就可以按照用户端设备的需求进行预览。但是,这种方法在用户端设备有预览需求的时候,才去通知预览设备与中继服务器建立连接,并且自身也同时才去与中继服务器建立连接,所耗费的时间比较长,用户端设备需要等待较长时间才能进行预览,用户端体验不是非常好。
可见,现有方案存在成本过高或者用户体验差的问题,本实施例基于该技术问题提出了一种流媒体数据预览方法,适用于音频、视频和多媒体文件。
如图1所示,图1为本申请第一实施例提供的一种流媒体数据预览系统的示意图。本实施例中流媒体数据预览方法对应的流媒体数据预览系统包括以下设备:用户端设备、预览设备以及中继服务器。
所述用户端设备,用于当检测到用户登录成功时,发送第一连接请求至所述中继服务器,与所述中继服务器建立第一连接,以及,发送预推流指令至预览设备;所述预推流指令用于指示所述预览设备发送第二连接请求至所述中继服务器,与所述中继服务器建立第二连接,并通过所述第二连接将实时流媒体数据推送至所述中继服务器进行缓存;当检测到预览请求时,发送预览请求至所述中继服务器;接收所述中继服务器通过所述第一连接返回的目标流媒体数据;所述目标流媒体数据为与所述预览请求对应的预览设备的实时流媒体数据;
所述中继服务器,用于当接收到用户端设备发送的第一连接请求时,与所述用户端设备建立第一连接;当接收到预览设备发送的第二连接请求时,与所述预览设备建立第二连接;接收所述预览设备通过所述第二连接推送的实时流媒体数据,并将所述实时流媒体数据存储至缓存区域;当接收到所述用户端设备发送的预览请求时,将所述缓存区域中的目标视流媒体数据通过所述第一连接发送至所述用户端设备;所述目标流媒体数据为与所述预览请求对应的预览设备的实时流媒体数据;
所述预览设备,用于当接收预推流指令时,发送第二连接请求至所述中继服务器,与所述中继服务器建立第二连接,并通过所述第二连接将实时流媒体数据推送至所述中继服务器。
用户端设备为用户使用的用来预览流媒体数据的设备,可以为手机、平板、台式电脑等等。预览设备为实时获取流媒体数据的设备,可以为摄像头、麦克风等等。中继服务器即为中继流媒体服务器。用户端设备检测到用户登录成功时,构建好预览设备和中继服务器、用户端设备和中继服务器之间的通道,让预览设备将实时流媒体数据提前发送到中继服务器。中继服务器接收到预览设备发送的实时流媒体数据,会缓存实时流媒体数据。当用户端设备进行实时预览的时候,中继服务器就会将缓存中的实时流媒体数据发送给用户端设备,让用户端设备在较短时间内就能获取并进行预览,而之后用户端设备接收到的流媒体数据还是设备实时发送并经过中继服务器的流媒体数据。
请参见图2,图2是本申请第二实施例提供的一种流媒体数据预览方法的示意流程图。本实施例中一种流媒体数据预览方法的执行主体为用户端设备。如图2所示的流媒体数据预览方法可包括:
S101:当检测到用户登录成功时,发送第一连接请求至所述中继服务器,与所述中继服务器建立第一连接,以及,发送预推流指令至预览设备;所述预推流指令用于指示所述预览设备发送第二连接请求至所述中继服务器,与所述中继服务器建立第二连接,并通过所述第二连接将实时流媒体数据推送至所述中继服务器进行缓存。
由于造成实时预览延迟的主要原因就是用户端设备/预览设备与中继服务器建立连接需要耗费大量时间。所以,本实施例中,用户端设备在用户登录成功、但未进行流媒体数据预览的时候,就与中继服务器建立连接,但不拉流;与此同时,用户端设备还需要通知预览设备与中继服务器建立连接。这样提前建立用户端设备/预览设备与中继服务器的连接,减少了时间的消耗。
本实施例中,用户端设备为用于进行流媒体数据预览的设备,用户进行流媒体数据预览时,为了验证身份,需要进行登录。用户可以通过账户名密码登录,也可以通过指纹或者面部识别登录。当用户端设备检测到用户登录成功时,发送第一连接请求至中继服务器,与中继服务器建立第一连接。其中,第一连接用于中继服务器向用户端设备发送目标流媒体数据。
用户端设备发送预推流指令至预览设备,预推流指令用于指示预览设备发送第二连接请求至中继服务器,与中继服务器建立第二连接,并通过第二连接将实时流媒体数据推送至中继服务器进行缓存。
其中,当流媒体数据为视频数据时,实时流媒体数据最大为一组连续的画面的数据(group of pictures,GOP),然后不断地用最新接收到的GOP数据替换前一个已经发送到中继服务器的GOP,保证中继服务器中的实时流媒体数据一直是最新的流媒体数据。
其中,第二连接用于预览设备将实时流媒体数据推送至中继服务器进行缓存。预览设备的数量为一个或者多个。相应的,当预览设备有多个时,也会对应的建立多个第二连接。
预览设备可以是用户端设备中预先设置好的,也可以是用户登录后进行选择的。在一个实施例中,用户在登录后,从设备列表中选择预览设备,在发送预推流指令至预览设备之前还可以包括S104~S105,如图3所示,S104~S105具体如下:
S104:显示设备列表;所述设备列表包括至少一台候选设备的信息。
用户端设备中预先存储设备列表,设备列表中包括至少一台候选设备的信息,候选设备的信息可以包括候选设备的标识、候选设备的位置信息等等。用户端设备检测到用户登录成功后,可以显示设备列表,用户可以对设备列表进行选择操作,从中选择出预览设备,例如,点击设备列表中的候选设备对应的选项,选中的候选设备作为预览设备。
S105:响应于用户对所述设备列表的选择操作,从所述候选设备中确定预览设备。
用户登录之后,用户端设备是处于与中继服务器建立好连接但未拉流的状态,预览设备是处与中继服务器连接并推送流媒体数据的状态。用户端设备提前与中继服务器建立好连接,这种连接状态需要发送心跳保活。每隔一段时间,用户端设备需要向中继服务器发送心跳请求,中继服务器接收到之后会返回响应告知用户端设备,预览设备是否还在向中继服务器发送实时流媒体数据。这样做是为了保证预览设备和中继服务器的第二连接的可用性,即预览设备可以持续向中继服务器发送目标流媒体数据,保证用户在进行预览时,可以即刻进行预览。所以,在发送预推流指令至预览设备之后还可以包括S106~S108,如图4所示,S106~S108具体如下:
S106:周期性地发送心跳请求至所述中继服务器。
本实施例中,采用了心跳机制,心跳机制是定时发送一个自定义的结构体,可以理解为心跳包,以确保连接的有效性的机制。用户端设备周期性地发送心跳请求至中继服务器,心跳请求用于告知中继服务器,用户端设备当前与中继服务器处于第一连接,并且触发中继服务器返回预览设备推送信息。中继服务器接收到心跳请求后,会确认当前是否还能接收到预览设备发送的实时流媒体数据,然后生成预览设备推送信息,预览设备推送信息可以包括停止推送信息或者保持推送信息,中继服务器将预览设备推送信息返回至用户端设备。
S107:接收所述中继服务器返回的预览设备推送信息。
用户端设备接收中继服务器返回的预览设备推送信息,根据预览设备推送信息确认当前中继服务器是否还能接收到预览设备发送的实时流媒体数据。
S108:若所述预览设备推送信息为停止推送信息,则发送所述预推流指令至所述预览设备。
若预览设备推送信息为停止推送信息,则发送预推流指令至预览设备,重新指示预览设备发送第二连接请求至中继服务器,与中继服务器建立第二连接,并通过第二连接将实时流媒体数据推送至中继服务器进行缓存。重新建立预览设备与中继服务器的第二连接。
可以理解的是,若预览设备推送信息为保持推送信息,则用户端设备继续等待用户进行实时预览。
S102:当检测到预览请求时,发送预览请求至所述中继服务器。
当用户需要进行实时预览时,用户可以触发用户端设备生成预览请求,或者用户可以触发其他设备向用户端设备发送预览请求。例如,用户可以通过点击用户端设备屏幕上的“开始预览”的虚拟按钮,触发用户端设备生成预览请求。
预览请求中包括用户想要预览的预览设备的信息。当用户端设备检测到预览请求时,发送预览请求至中继服务器。预览请求用于从中继服务器拉取预览设备对应的目标流媒体数据。当中继服务器接收到预览请求时,根据预览请求获取预览设备的信息,中继服务器查找是否有预览设备的信息对应的流媒体数据流通道,即查找中继服务器是否与预览设备建立了连接。如果查找有预览设备的信息对应的流媒体数据流通道,返回正常响应给用户端设备,用户端设备做好接收目标流媒体数据的准备。
S103:接收所述中继服务器通过所述第一连接返回的目标流媒体数据;所述目标流媒体数据为与所述预览请求对应的预览设备的实时流媒体数据。
用户端设备接收中继服务器通过第一连接返回的目标流媒体数据,并且播放目标流媒体数据,其中,目标流媒体数据为与所述预览请求对应的预览设备的实时流媒体数据。以视频为例,用户端设备可以直接播放预览视频的画面,之后中继服务器接着把实时的预览设备的流媒体数据发送给用户端设备,用户端设备可以持续地解析预览设备的流媒体数据,继续进行预览。
本申请实施例中,用户端设备当检测到用户登录成功时,发送第一连接请求至所述中继服务器,与所述中继服务器建立第一连接,以及,发送预推流指令至预览设备;当检测到预览请求时,发送预览请求至所述中继服务器;接收所述中继服务器通过所述第一连接返回的目标流媒体数据。上述方案,用户端设备在用户登录成功、但未进行流媒体数据预览的时候,就与中继服务器建立连接,但不拉流;与此同时用户端设备通知预览设备与中继服务器建立连接。这样提前建立用户端设备与中继服务器的连接,预览设备与中继服务器的连接,用户端设备不需要等待较长时间就可以进行预览,减少了时间的消耗,提升了用户的体验。
请参见图5,图5是本申请第二实施例提供的一种流媒体数据预览方法的示意流程图。本实施例中一种流媒体数据预览方法的执行主体为中继服务器。如图5所示的流媒体数据预览方法可包括:
S201:当接收到用户端设备发送的第一连接请求时,与所述用户端设备建立第一连接。
当用户端设备检测到用户登录成功时,用户端设备发送第一连接请求至中继服务器,中继服务器当接收到用户端设备发送的第一连接请求时,与用户端设备建立第一连接。其中,第一连接用于中继服务器像用户端设备发送目标流媒体数据。
S202:当接收到预览设备发送的第二连接请求时,与所述预览设备建立第二连接。
在本实施中,用户端设备发送预推流指令至预览设备,预推流指令用于指示预览设备发送第二连接请求至中继服务器,与中继服务器建立第二连接。当中继服务器接收到预览设备发送的第二连接请求时,与预览设备建立第二连接。其中,第二连接用于中继服务器接收由预览设备推送的实时流媒体数据。
当预览设备预连接到中继服务器,建立好推送设备流媒体数据流的通道的时候,中继服务器会对此预推流通道设置一定的存活时长,如果在此时长之内有用户端设备进行实时预览,则延长推流通道足够长的时间给用户端设备进行预览;如果在此时长之内没有用户端设备进行实时预览,则中继服务器会关闭预推流通道。这样设置的原因是为了降低中继服务器的压力和运行成本。所以,在S202之后,还可以包括:若在预设时长内未接收到所述用户端设备发送的预览请求,则断开所述第二连接。若中继服务器在预设时长内未接收到用户端设备发送的预览请求,没有用户进行实时预览,则断开第二连接。若中继服务器在预设时长内接收到用户端设备发送的预览请求,则延长推流通道足够长的时间给用户端设备进行预览。
S203:接收所述预览设备通过所述第二连接推送的实时流媒体数据,并将所述实时流媒体数据存储至缓存区域。
中继服务器接收预览设备通过第二连接推送的实时流媒体数据,并将实时流媒体数据存储至缓存区域。具体地说,当预览设备向中继服务器推送实时流媒体数据时,中继服务器会建立一块存储数据结构,用来存储实时流媒体数据。
当流媒体数据为视频数据时,存储的最大数据量为一个GOP数据体。当有新的一个GOP数据体来临时,会用新的一个完整的GOP数据或者已接收到的部分GOP数据替换掉原先的一个GOP数据体,用来保证中继服务器缓存的实时流媒体数据永远是最新的实时流媒体数据,这样客户端最先从中继服务器缓存中获取到的流媒体数据就是实时的。
所以,在S203之后,还可以包括:当接收到预览设备发送的新的实时流媒体数据时,删除缓存区域中预览设备对应的实时流媒体数据,将预览设备发送的新的实时流媒体数据存储至缓存区域。
S204:当接收到所述用户端设备发送的预览请求时,将所述缓存区域中的目标流媒体数据通过所述第一连接发送至所述用户端设备;所述目标流媒体数据为与所述预览请求对应的预览设备的实时流媒体数据。
当用户需要进行实时预览时,用户可以触发用户端设备生成预览请求,或者用户可以触发其他设备向用户端设备发送预览请求。当用户端设备检测到预览请求时,发送预览请求至中继服务器。当中继服务器接收到用户端设备发送的预览请求时,将缓存区域中的目标流媒体数据通过第一连接发送至用户端设备,其中,目标流媒体数据为与预览请求对应的预览设备的实时流媒体数据。预览请求中包括用户想要预览的预览设备的信息。具体地说,当中继服务器接收到预览请求时,根据预览请求获取预览设备的信息,中继服务器查找是否有预览设备的信息对应的流媒体数据流通道,即查找中继服务器是否与预览设备建立了连接。如果查找有预览设备的信息对应的流媒体数据流通道,返回正常响应给用户端设备,用户端设备做好接收目标流媒体数据的准备,然后,中继服务器将缓存区域中的目标流媒体数据通过第一连接发送至用户端设备。
进一步地,当有多个用户端设备进行同一个预览设备相同码流的实时预览时,会复用同一个预览设备的推流通道。当流媒体数据为视频数据时,可以先从中继服务器缓存中获取到一个完整的GOP流媒体数据或者其中的一部分,再之后获取到的就是非缓存流,是设备实时发送并经过relay服务器传输的视频流。
本实施例中,中继服务器当接收到用户端设备发送的第一连接请求时,与所述用户端设备建立第一连接;当接收到预览设备发送的第二连接请求时,与所述预览设备建立第二连接;接收所述预览设备通过所述第二连接推送的实时流媒体数据,并将所述实时流媒体数据存储至缓存区域;当接收到所述用户端设备发送的预览请求时,将所述缓存区域中的目标流媒体数据通过所述第一连接发送至所述用户端设备。上述方案,中继服务器在用户登录成功、但未进行流媒体数据预览的时候,就与用户端设备建立连接,但用户端设备不拉流;与此同时,与预览设备建立连接。这样提前建立用户端设备与中继服务器的连接,预览设备与中继服务器的连接,用户端设备不需要等待较长时间就可以进行预览,减少了时间的消耗,提升了用户的体验。
下面,结合具体的应用场景对本申请实施例提供的流媒体数据预览方法进行描述:
当用户需要使用用户端设备观看预览视频时,可以登录预览视频的应用程序,为了验证身份,需要进行登录。用户可以通过账户名密码登录,也可以通过指纹或者面部识别登录。当用户端设备检测到用户登录成功时,用户端设备发送第一连接请求至中继服务器,与中继服务器建立第一连接。
用户登录后,用户端设备可以显示设备列表,设备列表中可以包括候选设备的标识,例如,候选设备1、候选设备2、候选设备3等等。用户可以从设备类别中选择预览设备,用户可以点击候选设备的标识对应的虚拟按钮,将选中的候选设备作为预览设备。用户可以选择一个候选设备作为预览设备,也可以选择多个候选设备作为预览设备。用户设备相应用户对设备列表的选择操作,从候选设备中确定预览设备。例如,用户点击了“候选设备1”对应的虚拟按钮,那么用户设备相应用户对设备列表的选择操作,将候选设备1作为预览设备。
用户端设备发送预推流指令至候选设备1,预推流指令用于指示候选设备1发送第二连接请求至中继服务器,与中继服务器建立第二连接,并通过第二连接将实时流媒体数据推送至中继服务器进行缓存。
每隔一段时间,用户端设备可以向中继服务器发送心跳请求,中继服务器接收到之后会返回响应告知用户端设备,候选设备1是否还在向中继服务器发送实时流媒体数据。若预览设备推送信息为停止推送信息,则发送预推流指令至候选设备1,重新指示候选设备1发送第二连接请求至中继服务器,与中继服务器建立第二连接,并通过第二连接将实时流媒体数据推送至中继服务器进行缓存。
用户可以通过点击用户端设备屏幕上的“开始预览”的虚拟按钮,触发用户端设备生成预览请求。预览请求中包括用户想要预览的候选设备1的信息。当用户端设备检测到预览请求时,发送预览请求至中继服务器。用户端设备接收中继服务器通过第一连接返回的目标流媒体数据,并且播放目标流媒体数据,其中,目标流媒体数据为与预览请求对应的候选设备1的实时流媒体数据。
应理解,上述实施例中各步骤的序号的大小并不意味着执行顺序的先后,各过程的执行顺序应以其功能和内在逻辑确定,而不应对本申请实施例的实施过程构成任何限定。
请参见图6,图6是本申请第三实施例提供的用户端设备的示意图。包括的各单元用于执行图2~图4对应的实施例中的各步骤,具体请参阅图2~图4对应的实施例中的相关描述。为了便于说明,仅示出了与本实施例相关的部分。参见图6,用户端设备6包括:
第一处理单元610,用于当检测到用户登录成功时,发送第一连接请求至所述中继服务器,与所述中继服务器建立第一连接,以及,发送预推流指令至预览设备;所述预推流指令用于指示所述预览设备发送第二连接请求至所述中继服务器,与所述中继服务器建立第二连接,并通过所述第二连接将实时流媒体数据推送至所述中继服务器进行缓存;
第二处理单元620,用于当检测到预览请求时,发送预览请求至所述中继服务器;
第三处理单元630,用于接收所述中继服务器通过所述第一连接返回的目标流媒体数据;所述目标流媒体数据为与所述预览请求对应的预览设备的实时流媒体数据。
进一步地,用户端设备6,还包括:
显示单元,用于显示设备列表;所述设备列表包括至少一台候选设备的信息;
第四处理单元,用于响应于用户对所述设备列表的选择操作,从所述候选设备中确定预览设备。
进一步地,用户端设备6,还包括:
发送单元,用于周期性地发送心跳请求至所述中继服务器;
接收单元,用于接收所述中继服务器返回的预览设备推送信息;
第五处理单元,用于若所述预览设备推送信息为停止推送信息,则发送所述预推流指令至所述预览设备。
进一步地,所述预览设备的数量为一个或者多个。
请参见图7,图7是本申请第四实施例提供的中继服务器的示意图。包括的各单元用于执行图5对应的实施例中的各步骤,具体请参阅图5对应的实施例中的相关描述。为了便于说明,仅示出了与本实施例相关的部分。参见图7,中继服务器7包括:
第一处理单元710,用于当接收到用户端设备发送的第一连接请求时,与所述用户端设备建立第一连接;
第二处理单元720,用于当接收到预览设备发送的第二连接请求时,与所述预览设备建立第二连接;
第三处理单元730,用于接收所述预览设备通过所述第二连接推送的实时流媒体数据,并将所述实时流媒体数据存储至缓存区域;
第四处理单元740,用于当接收到所述用户端设备发送的预览请求时,将所述缓存区域中的目标流媒体数据通过所述第一连接发送至所述用户端设备;所述目标流媒体数据为与所述预览请求对应的预览设备的实时流媒体数据。
进一步地,中继服务器7,还包括:
第五处理单元,用于若在预设时长内未接收到所述用户端设备发送的预览请求,则断开所述第二连接。
进一步地,中继服务器7,还包括:
第六处理单元,用于当接收到所述预览设备发送的新的实时流媒体数据时,删除所述缓存区域中所述预览设备对应的实时流媒体数据,将所述预览设备发送的新的实时流媒体数据存储至所述缓存区域。
图8是本申请第五实施例提供的用户端设备的示意图。如图8所示,该实施例的用户端设备8包括:处理器80、存储器81以及存储在所述存储器81中并可在所述处理器80上运行的计算机程序82,例如流媒体数据预览程序。所述处理器80执行所述计算机程序82时流媒体数据预览方法实施例中的步骤,例如图1所示的步骤101至103。或者,所述处理器80执行所述计算机程序82时实现上述各装置实施例中各模块/单元的功能,例如图6所示模块610至630的功能。
示例性的,所述计算机程序82可以被分割成一个或多个模块/单元,所述一个或者多个模块/单元被存储在所述存储器81中,并由所述处理器80执行,以完成本申请。所述一个或多个模块/单元可以是能够完成特定功能的一系列计算机程序指令段,该指令段用于描述所述计算机程序82在所述用户端设备8中的执行过程。例如,所述计算机程序82可以被分割成第一处理单元、第二处理单元、第三处理单元,各单元具体功能如下:
第一处理单元,用于当检测到用户登录成功时,发送第一连接请求至所述中继服务器,与所述中继服务器建立第一连接,以及,发送预推流指令至预览设备;所述预推流指令用于指示所述预览设备发送第二连接请求至所述中继服务器,与所述中继服务器建立第二连接,并通过所述第二连接将实时流媒体数据推送至所述中继服务器进行缓存;
第二处理单元,用于当检测到预览请求时,发送预览请求至所述中继服务器;
第三处理单元,用于接收所述中继服务器通过所述第一连接返回的目标流媒体数据;所述目标流媒体数据为与所述预览请求对应的预览设备的实时流媒体数据。
所述用户端设备可包括,但不仅限于,处理器80、存储器81。本领域技术人员可以理解,图8仅仅是用户端设备8的示例,并不构成对用户端设备8的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件,例如所述用户端设备还可以包括输入输出设备、网络接入设备、总线等。
所称处理器80可以是中央处理单元(Central Processing Unit,CPU),还可以是其他通用处理器、数字信号处理器(Digital Signal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现成可编程门阵列(Field-Programmable Gate Array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
所述存储器81可以是所述用户端设备8的内部存储单元,例如用户端设备8的硬盘或内存。所述存储器81也可以是所述用户端设备8的外部存储设备,例如用户端设备8上配备的插接式硬盘,智能存储卡(Smart Media Card,SMC),安全数字(Secure Digital,SD)卡,闪存卡(Flash Card)等。进一步地,所述存储器81还可以既包括所述用户端设备8的内部存储单元也包括外部存储设备。所述存储器81用于存储所述计算机程序以及所述用户端设备所需的其他程序和数据。所述存储器81还可以用于暂时地存储已经输出或者将要输出的数据。
图9是本申请第六实施例提供的中继服务器的示意图。如图9所示,该实施例的中继服务器9包括:处理器90、存储器91以及存储在所述存储器91中并可在所述处理器90上运行的计算机程序92,例如流媒体数据预览程序。所述处理器90执行所述计算机程序92时流媒体数据预览方法实施例中的步骤,例如图5所示的步骤201至204。或者,所述处理器90执行所述计算机程序92时实现上述各装置实施例中各模块/单元的功能,例如图7所示模块710至740的功能。
示例性的,所述计算机程序92可以被分割成一个或多个模块/单元,所述一个或者多个模块/单元被存储在所述存储器91中,并由所述处理器90执行,以完成本申请。所述一个或多个模块/单元可以是能够完成特定功能的一系列计算机程序指令段,该指令段用于描述所述计算机程序92在所述中继服务器9中的执行过程。例如,所述计算机程序92可以被分割成第一处理单元、第二处理单元、第三处理单元、第四处理单元,各单元具体功能如下:
第一处理单元,用于当接收到用户端设备发送的第一连接请求时,与所述用户端设备建立第一连接;
第二处理单元,用于当接收到预览设备发送的第二连接请求时,与所述预览设备建立第二连接;
第三处理单元,用于接收所述预览设备通过所述第二连接推送的实时流媒体数据,并将所述实时流媒体数据存储至缓存区域;
第四处理单元,用于当接收到所述用户端设备发送的预览请求时,将所述缓存区域中的目标流媒体数据通过所述第一连接发送至所述用户端设备;所述目标流媒体数据为与所述预览请求对应的预览设备的实时流媒体数据。
所述中继服务器可包括,但不仅限于,处理器90、存储器91。本领域技术人员可以理解,图9仅仅是中继服务器9的示例,并不构成对中继服务器9的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件,例如所述中继服务器还可以包括输入输出设备、网络接入设备、总线等。
所称处理器90可以是中央处理单元(Central Processing Unit,CPU),还可以是其他通用处理器、数字信号处理器(Digital Signal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现成可编程门阵列(Field-Programmable Gate Array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
所述存储器91可以是所述中继服务器9的内部存储单元,例如中继服务器9的硬盘或内存。所述存储器91也可以是所述中继服务器9的外部存储设备,例如中继服务器9上配备的插接式硬盘,智能存储卡(Smart Media Card,SMC),安全数字(Secure Digital,SD)卡,闪存卡(Flash Card)等。进一步地,所述存储器91还可以既包括所述中继服务器9的内部存储单元也包括外部存储设备。所述存储器91用于存储所述计算机程序以及所述中继服务器所需的其他程序和数据。所述存储器91还可以用于暂时地存储已经输出或者将要输出的数据。
所属领域的技术人员可以清楚地了解到,为了描述的方便和简洁,仅以上述各功能单元、模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能单元、模块完成,即将所述装置的内部结构划分成不同的功能单元或模块,以完成以上描述的全部或者部分功能。实施例中的各功能单元、模块可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中,上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。另外,各功能单元、模块的具体名称也只是为了便于相互区分,并不用于限制本申请的保护范围。上述系统中单元、模块的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
在上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述或记载的部分,可以参见其它实施例的相关描述。
本领域普通技术人员可以意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、或者计算机软件和电子硬件的结合来实现。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本申请的范围。
在本申请所提供的实施例中,应该理解到,所揭露的装置/终端设备和方法,可以通过其它的方式实现。例如,以上所描述的装置/终端设备实施例仅仅是示意性的,例如,所述模块或单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通讯连接可以是通过一些接口,装置或单元的间接耦合或通讯连接,可以是电性,机械或其它的形式。
所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本申请各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。
所述集成的模块/单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本申请实现上述实施例方法中的全部或部分流程,也可以通过计算机程序来指令相关的硬件来完成,所述的计算机程序可存储于一计算机可读存储介质中,该计算机程序在被处理器执行时,可实现上述各个方法实施例的步骤。。其中,所述计算机程序包括计算机程序代码,所述计算机程序代码可以为源代码形式、对象代码形式、可执行文件或某些中间形式等。所述计算机可读介质可以包括:能够携带所述计算机程序代码的任何实体或装置、记录介质、U盘、移动硬盘、磁碟、光盘、计算机存储器、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)、电载波信号、电信信号以及软件分发介质等。需要说明的是,所述计算机可读介质包含的内容可以根据司法管辖区内立法和专利实践的要求进行适当的增减,例如在某些司法管辖区,根据立法和专利实践,计算机可读介质不包括电载波信号和电信信号。
以上所述实施例仅用以说明本申请的技术方案,而非对其限制;尽管参照前述实施例对本申请进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本申请各实施例技术方案的精神和范围,均应包含在本申请的保护范围之内。
Claims (10)
1.一种流媒体数据预览方法,其特征在于,应用于用户端设备,所述方法包括:
当检测到用户登录成功时,发送第一连接请求至所述中继服务器,与所述中继服务器建立第一连接,以及,发送预推流指令至预览设备;所述预推流指令用于指示所述预览设备发送第二连接请求至所述中继服务器,与所述中继服务器建立第二连接,并通过所述第二连接将实时流媒体数据推送至所述中继服务器进行缓存;
当检测到预览请求时,发送预览请求至所述中继服务器;
接收所述中继服务器通过所述第一连接返回的目标流媒体数据;所述目标流媒体数据为与所述预览请求对应的预览设备的实时流媒体数据。
2.如权利要求1所述的流媒体数据预览方法,其特征在于,在所述发送预推流指令至预览设备之前,包括:
显示设备列表;所述设备列表包括至少一台候选设备的信息;
响应于用户对所述设备列表的选择操作,从所述候选设备中确定预览设备。
3.如权利要求1所述的流媒体数据预览方法,其特征在于,在所述发送预推流指令至预览设备之后,还包括:
周期性地发送心跳请求至所述中继服务器;
接收所述中继服务器返回的预览设备推送信息;
若所述预览设备推送信息为停止推送信息,则发送所述预推流指令至所述预览设备。
4.如权利要求1所述的流媒体数据预览方法,其特征在于,所述预览设备的数量为一个或者多个。
5.一种流媒体数据预览方法,其特征在于,应用于中继服务器,所述方法包括:
当接收到用户端设备发送的第一连接请求时,与所述用户端设备建立第一连接;
当接收到预览设备发送的第二连接请求时,与所述预览设备建立第二连接;
接收所述预览设备通过所述第二连接推送的实时流媒体数据,并将所述实时流媒体数据存储至缓存区域;
当接收到所述用户端设备发送的预览请求时,将所述缓存区域中的目标视流媒体数据通过所述第一连接发送至所述用户端设备;所述目标流媒体数据为与所述预览请求对应的预览设备的实时流媒体数据。
6.如权利要求5所述的流媒体数据预览方法,其特征在于,在所述与所述预览设备建立第二连接之后,还包括:
若在预设时长内未接收到所述用户端设备发送的预览请求,则断开所述第二连接。
7.如权利要求5所述的流媒体数据预览方法,其特征在于,在所述接收所述预览设备推送的实时流媒体数据,并将所述实时流媒体数据存储至缓存区域之后,还包括:
当接收到所述预览设备发送的新的实时流媒体数据时,删除所述缓存区域中所述预览设备对应的实时流媒体数据,将所述预览设备发送的新的实时流媒体数据存储至所述缓存区域。
8.一种用户端设备,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现如权利要求1至4任一项所述的方法。
9.一种中继服务器,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现如权利要求5至7任一项所述的方法。
10.一种流媒体数据预览系统,其特征在于,所述系统包括用户端设备、中继服务器、预览设备;
所述用户端设备,用于当检测到用户登录成功时,发送第一连接请求至所述中继服务器,与所述中继服务器建立第一连接,以及,发送预推流指令至预览设备;所述预推流指令用于指示所述预览设备发送第二连接请求至所述中继服务器,与所述中继服务器建立第二连接,并通过所述第二连接将实时流媒体数据推送至所述中继服务器进行缓存;当检测到预览请求时,发送预览请求至所述中继服务器;接收所述中继服务器通过所述第一连接返回的目标流媒体数据;所述目标流媒体数据为与所述预览请求对应的预览设备的实时流媒体数据;
所述中继服务器,用于当接收到用户端设备发送的第一连接请求时,与所述用户端设备建立第一连接;当接收到预览设备发送的第二连接请求时,与所述预览设备建立第二连接;接收所述预览设备通过所述第二连接推送的实时流媒体数据,并将所述实时流媒体数据存储至缓存区域;当接收到所述用户端设备发送的预览请求时,将所述缓存区域中的目标视流媒体数据通过所述第一连接发送至所述用户端设备;所述目标流媒体数据为与所述预览请求对应的预览设备的实时流媒体数据;
所述预览设备,用于当接收预推流指令时,发送第二连接请求至所述中继服务器,与所述中继服务器建立第二连接,并通过所述第二连接将实时流媒体数据推送至所述中继服务器。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010988958.1A CN112073747A (zh) | 2020-09-18 | 2020-09-18 | 一种流媒体数据预览方法、用户端设备及中继服务器 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010988958.1A CN112073747A (zh) | 2020-09-18 | 2020-09-18 | 一种流媒体数据预览方法、用户端设备及中继服务器 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN112073747A true CN112073747A (zh) | 2020-12-11 |
Family
ID=73682065
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202010988958.1A Pending CN112073747A (zh) | 2020-09-18 | 2020-09-18 | 一种流媒体数据预览方法、用户端设备及中继服务器 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN112073747A (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112804540A (zh) * | 2020-12-30 | 2021-05-14 | 北京大米科技有限公司 | 媒体流的推送方法、装置、存储介质及电子设备 |
Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2013078620A1 (zh) * | 2011-11-29 | 2013-06-06 | 华为技术有限公司 | 一种分发直播内容的方法、设备和系统 |
CN104184944A (zh) * | 2014-08-15 | 2014-12-03 | 小米科技有限责任公司 | 获取多媒体数据流的方法及装置 |
CN105872391A (zh) * | 2016-06-15 | 2016-08-17 | 华为技术有限公司 | 网络摄像机的控制方法、装置及系统 |
US20160337426A1 (en) * | 2015-05-14 | 2016-11-17 | Hola Networks Ltd. | System and Method for Streaming Content from Multiple Servers |
CN107820043A (zh) * | 2016-09-14 | 2018-03-20 | 华为技术有限公司 | 视频监控系统的控制方法、装置及系统 |
CN109151494A (zh) * | 2017-06-19 | 2019-01-04 | 杭州萤石网络有限公司 | 多媒体数据传输方法、多媒体采集设备及服务器 |
CN110445682A (zh) * | 2019-08-05 | 2019-11-12 | 深圳市大拿科技有限公司 | 监测联网节点存活状态的方法、服务器、设备及系统 |
-
2020
- 2020-09-18 CN CN202010988958.1A patent/CN112073747A/zh active Pending
Patent Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2013078620A1 (zh) * | 2011-11-29 | 2013-06-06 | 华为技术有限公司 | 一种分发直播内容的方法、设备和系统 |
CN104184944A (zh) * | 2014-08-15 | 2014-12-03 | 小米科技有限责任公司 | 获取多媒体数据流的方法及装置 |
US20160337426A1 (en) * | 2015-05-14 | 2016-11-17 | Hola Networks Ltd. | System and Method for Streaming Content from Multiple Servers |
CN105872391A (zh) * | 2016-06-15 | 2016-08-17 | 华为技术有限公司 | 网络摄像机的控制方法、装置及系统 |
CN107820043A (zh) * | 2016-09-14 | 2018-03-20 | 华为技术有限公司 | 视频监控系统的控制方法、装置及系统 |
CN109151494A (zh) * | 2017-06-19 | 2019-01-04 | 杭州萤石网络有限公司 | 多媒体数据传输方法、多媒体采集设备及服务器 |
CN110445682A (zh) * | 2019-08-05 | 2019-11-12 | 深圳市大拿科技有限公司 | 监测联网节点存活状态的方法、服务器、设备及系统 |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112804540A (zh) * | 2020-12-30 | 2021-05-14 | 北京大米科技有限公司 | 媒体流的推送方法、装置、存储介质及电子设备 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110290217B (zh) | 数据请求的处理方法及装置、存储介质及电子装置 | |
US11356748B2 (en) | Method, apparatus and system for slicing live streaming | |
CN109152095B (zh) | 用于终端的无线网络连接方法 | |
CN112104897B (zh) | 视频获取方法、终端及存储介质 | |
CN106998485B (zh) | 视频直播方法及装置 | |
CN112087644B (zh) | 拉流请求处理方法、装置、系统、电子设备和存储介质 | |
CN109152094B (zh) | 用于终端的无线网络连接方法 | |
WO2020094036A1 (zh) | 用于终端的无线网络连接方法 | |
CN105871800A (zh) | 一种拉流控制的方法、装置及系统 | |
US20170171585A1 (en) | Method and Electronic Device for Recording Live Streaming Media | |
US20170163706A1 (en) | Method, electronic device and system for controlling pull stream | |
CN109151494A (zh) | 多媒体数据传输方法、多媒体采集设备及服务器 | |
CN110933517A (zh) | 码率切换方法、客户端和计算机可读存储介质 | |
CN114928758A (zh) | 直播异常检测处理方法及装置 | |
CN111246238A (zh) | 直播方法、装置、存储介质及直播系统 | |
CN112073747A (zh) | 一种流媒体数据预览方法、用户端设备及中继服务器 | |
CN105407148A (zh) | 一种基于客户端的网络数据同步的方法、装置以及系统 | |
CN111866544B (zh) | 数据处理方法、装置、设备及计算机可读存储介质 | |
CN115002527B (zh) | 数据传输优化方法、装置、设备及存储介质 | |
CN114095660B (zh) | 图像显示方法、装置、存储介质及电子设备 | |
CN114025184B (zh) | 一种视频直播方法及电子设备 | |
CN113163226B (zh) | 媒体文件的播放方法、装置、电子设备、服务器和介质 | |
CN113473247B (zh) | 一种视频播放请求处理方法、装置、系统和电子设备 | |
CN115297095A (zh) | 回源处理方法、装置、计算设备及存储介质 | |
CN114051150A (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 | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20201211 |
|
RJ01 | Rejection of invention patent application after publication |