CN107592554B - 直播视频转发方法及装置 - Google Patents
直播视频转发方法及装置 Download PDFInfo
- Publication number
- CN107592554B CN107592554B CN201710849241.7A CN201710849241A CN107592554B CN 107592554 B CN107592554 B CN 107592554B CN 201710849241 A CN201710849241 A CN 201710849241A CN 107592554 B CN107592554 B CN 107592554B
- Authority
- CN
- China
- Prior art keywords
- live
- agreement
- user terminal
- data streams
- protocol
- 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 35
- 238000006243 chemical reaction Methods 0.000 claims abstract description 29
- 238000004891 communication Methods 0.000 claims abstract description 12
- 238000004458 analytical method Methods 0.000 claims description 6
- 230000001419 dependent effect Effects 0.000 claims description 6
- 230000005540 biological transmission Effects 0.000 abstract description 7
- 230000006870 function Effects 0.000 description 13
- 238000010586 diagram Methods 0.000 description 11
- 230000008569 process Effects 0.000 description 7
- 230000003993 interaction Effects 0.000 description 6
- 238000004590 computer program Methods 0.000 description 2
- 238000005516 engineering process Methods 0.000 description 2
- 230000015572 biosynthetic process Effects 0.000 description 1
- 238000004364 calculation method Methods 0.000 description 1
- 230000008859 change Effects 0.000 description 1
- 230000007812 deficiency Effects 0.000 description 1
- 238000009434 installation Methods 0.000 description 1
Abstract
本发明提供一种直播视频转发方法及装置,应用于与资源服务器及用户终端通信的节点服务器,方法包括:接收用户终端发送的视频获取请求,视频获取请求用于获取目标直播视频源;解析视频获取请求,若视频获取请求的协议为预设的第一协议,与该用户终端建立第一协议的直播会话;从资源服务器获取目标直播视频源的第二协议的直播数据流,从直播数据流中解析获得有效数据流,第二协议为非开放协议;将有效数据流通过第一协议的直播会话发送给用户终端。如此,在不改变节点服务从资源服务器获取直播视频流订阅模式的情况下,实现了直播视频流的传输方式从采用非开放的第二协议向开放的第一协议的转换,降低了用户终端接收直播视频的故障率。
Description
技术领域
本发明涉及数据处理技术领域,具体而言,涉及一种直播视频转发方法及装置。
背景技术
在直播视频的播出过程中,为了缓解资源服务器的压力提供用户获取直播视频的速度,常采用内容分发网络(Content Delivery Network,CDN)进行数据缓存,通过CDN节点服务器从资源服务器获取直播流数据,用户终端从最近的CDN节点服务器获取转发的直播流数据。
现有技术的直播视频转发方式中,CDN节点服务器与资源服务器和用户终端之间均采用的是非开放协议(如rtmp协议),但是CDN节点服务器与用户终端之间通过非开放协议可能会被用户终端的防火墙拦截,导致用户终端的直播视频出现无法播出或卡顿华品的现象。
发明内容
为了克服现有技术中的上述不足,本发明的目的在于提供一种直播视频转发方法,应用于与资源服务器及用户终端通信的节点服务器,所述方法包括:
接收所述用户终端发送的视频获取请求,所述视频获取请求用于获取目标直播视频源;
解析所述视频获取请求,得到该视频获取请求的协议类型,并判断该协议是否为预设的第一协议;
若所述视频获取请求的协议为预设的第一协议,与该用户终端建立第一协议的直播会话;
从所述资源服务器获取所述目标直播视频源的第二协议的直播数据流,从所述直播数据流中解析获得有效数据流;
将所述有效数据流通过所述第一协议的直播会话发送给所述用户终端。
可选地,在上述方法中,所述第一协议包括http协议,所述第二协议包括rtmp协议。
可选地,在上述方法中,所述节点服务器中预设有用于进行视频转发处理的Nginx-rtmp模块,所述Nginx-rtmp模块包括用于标识直播数据流协议转换功能是否开启的转换使能标识;所述与该用户终端建立第一协议的直播会话的步骤,包括:
检测所述Nginx-rtmp模块的转换使能标识是否标识为开启状态;
在所述转换使能标识为开启状态时,再与所述用户终端建立所述第一协议的直播会话。
可选地,在上述方法中,所述从所述资源服务器获取所述目标直播视频源的第二协议的直播数据流,从所述直播数据流中解析获得有效数据流的步骤,包括:
检测所述Nginx-rtmp模块的直播数据流接收队列中待接收的直播数据流数量是否超过预设阈值;
当超过所述预设阈值时,舍弃接收到的直播数据流;
当没有超过所述预设阈值时,将接收到的所述直播数据流中rtmp协议相关的数据头去除,采用浅拷贝的方式复制所述直播数据流相关的引用,得到有效数据流。
可选地,在上述方法中,所述节点服务器中预设有用于存储已建立的直播会话的订阅队列;所述将所述有效数据流通过所述第一协议的直播会话发送给相应的用户终端的步骤,包括:
遍历所述订阅队列,将所述有效数据流的发送给所述订阅队列中的直播会话,使所述用户终端通过所述第一协议的直播会话获得的所述有效数据流。
本发明还提供一种直播视频转发装置,应用于与资源服务器及用户终端通信的节点服务器,所述装置包括:
请求接收模块,用于接收所述用户终端发送的视频获取请求,所述视频获取请求用于获取目标直播视频源;
请求解析模块,用于解析所述视频获取请求,得到该视频获取请求的协议类型,并判断该协议是否为预设的第一协议,所述第一协议为开放协议;
会话建立模块,用于当所述视频获取请求的协议为预设的第一协议时,与该用户终端建立第一协议的直播会话;
有效数据获取模块,用于从所述资源服务器获取所述目标直播视频源的第二协议的直播数据流,从所述直播数据流中解析获得有效数据流,所述第二协议为非开放协议;
发送模块,用于将所述有效数据流通过所述第一协议的直播会话发送给所述用户终端。
可选地,在上述装置中,所述第一协议包括http协议,所述第二协议包括rtmp协议。
可选地,在上述装置中,所述节点服务器中预设有用于进行视频转发处理的Nginx-rtmp模块,所述Nginx-rtmp模块包括用于标识直播数据流协议转换功能是否开启的转换使能标识;所述会话建立模块通过以下方式与该用户终端建立第一协议的直播会话:
检测所述Nginx-rtmp模块的转换使能标识是否标识为开启状态;
在所述转换使能标识为开启状态时,再与所述用户终端建立所述第一协议的直播会话。
可选地,在上述装置中,所述有效数据获取模块通过以下方式从所述直播数据流中解析获得有效数据流:
检测所述Nginx-rtmp模块的直播数据流接收队列中待接收的直播数据流数量是否超过预设阈值;
当超过所述预设阈值时,舍弃接收到的直播数据流;
当没有超过所述预设阈值时,将接收到的所述直播数据流中rtmp协议相关的数据头去除,采用浅拷贝的方式复制所述直播数据流相关的引用,得到有效数据流。
可选地,在上述装置中,所述节点服务器中预设有用于存储已建立的直播会话的订阅队列;所述发送模块通过以下方式将所述有效数据流通过发送给相应的用户终端:
遍历所述订阅队列,将所述有效数据流的发送给所述订阅队列中的直播会话,使所述用户终端通过所述第一协议的直播会话获得的所述有效数据流。
相对于现有技术而言,本发明具有以下有益效果:
本发明提供的直播视频转发方法及装置,通过将接收用户终端发送的视频获取请求,将接收到的第二协议的直播视频流转换为与所述视频获取请求对应的第一协议的直播视频流。如此,在不改变节点服务从资源服务器获取直播视频流订阅模式的情况下,实现了直播视频流的传输方式从采用非开放的第二协议向开放的第一协议的转换,降低了用户终端接收所述直播视频的故障率。
附图说明
为了更清楚地说明本发明实施例的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,应当理解,以下附图仅示出了本发明的某些实施例,因此不应被看作是对范围的限定,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他相关的附图。
图1为本发明实施例提供的节点服务器与用户终端及资源服务器的交互示意图;
图2为本发明实施例提供的节点服务器的结构框图;
图3为本发明实施例提供的直播视频转发方法的步骤流程示意图;
图4为本发明实施例提供的直播视频转发装置的示意图。
图标:100-节点服务器;110-直播视频转发装置;111-请求接收模块;112-请求解析模块;113-会话建立模块;114-有效数据获取模块;115-发送模块;120-存储器;130-处理器;140-通信单元;200-用户终端;300-资源服务器。
具体实施方式
为使本发明实施例的目的、技术方案和优点更加清楚,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。通常在此处附图中描述和示出的本发明实施例的组件可以以各种不同的配置来布置和设计。
因此,以下对在附图中提供的本发明的实施例的详细描述并非旨在限制要求保护的本发明的范围,而是仅仅表示本发明的选定实施例。基于本发明中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释。
在本发明的描述中,需要说明的是,术语“第一”、“第二”、“第三”等仅用于区分描述,而不能理解为指示或暗示相对重要性。
在本发明的描述中,还需要说明的是,除非另有明确的规定和限定,术语“设置”、“安装”、“相连”、“连接”应做广义理解,例如,可以是固定连接,也可以是可拆卸连接,或一体地连接;可以是机械连接,也可以是电连接;可以是直接相连,也可以通过中间媒介间接相连,可以是两个元件内部的连通。对于本领域的普通技术人员而言,可以具体情况理解上述术语在本发明中的具体含义。
请参照图1,图1是本发明较佳实施例提供的节点服务器100与资源服务器300至少一用户终端200通信的交互示意图。
请参照图2,图2是图1所示的节点服务器100的方框示意图。所述节点服务器100包括直播视频转发装置110、存储器120、处理器130、通信单元140。
所述存储器120、处理器130以及通信单元140各元件相互之间直接或间接地电性连接,以实现数据的传输或交互。例如,这些元件相互之间可通过一条或多条通讯总线或信号线实现电性连接。所述直播视频转发装置110包括至少一个可以软件或固件(firmware)的形式存储于所述存储器120中或固化在所述节点服务器100的操作系统(operatingsystem,OS)中的软件功能模块。所述处理器130用于执行所述存储器120中存储的可执行模块,例如所述直播视频转发装置110所包括的软件功能模块及计算机程序等。
其中,所述存储器120可以是,但不限于,随机存取存储器(Random AccessMemory,RAM),只读存储器(Read Only Memory,ROM),可编程只读存储器(ProgrammableRead-Only Memory,PROM),可擦除只读存储器(Erasable Programmable Read-OnlyMemory,EPROM),电可擦除只读存储器(Electric Erasable Programmable Read-OnlyMemory,EEPROM)等。其中,存储器120用于存储程序,所述处理器130在接收到执行指令后,执行所述程序。
所述处理器130可能是一种集成电路芯片,具有信号的处理能力。上述的处理器可以是通用处理器,包括中央处理器(Central Processing Unit,CPU)、网络处理器(NetworkProcessor,NP)等;还可以是数字信号处理器(DSP)、专用集成电路(ASIC)、现场可编程门阵列(FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。可以实现或者执行本发明实施例中的公开的各方法、步骤及逻辑框图。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
所述通信单元140用于建立所述节点服务器100与用户终端200及资源服务器300之间的通信连接。
经发明人大量研究发现,现有技术中节点服务器100常采用非开放协议(如rtmp协议)的数据转发协议进行直播视频的转发,但是非开放协议传输的数据容易被用户终端200的防火墙拦截,导致视频无法播出或部分卡顿花屏。故在本实施例中,在节点服务器100后端服务的非开放的第二协议的直播数据口分发到用户终端前转换为开放的第一协议,如此,降低直播视频播出的故障率。其中,所述第二协议可以为rtmp协议,所述第一协议可以为http协议。
以Nginx+rtmp模块为例,在本实施例中,预设有用于进行视频转发处理的Nginx-rtmp模块,所述Nginx-rtmp模块包括与直播视频源对应的application对象,所述application对象中包括预设的用于标识直播数据流协议转换功能是否开启的转换使能标识。
在本实施例中,预先在所述Nginx-rtmp模块配置的http-rtmp模块,在所述http-rtmp模块添加http-flv子模块。并在Nginx-rtmp模块的conf文件中,将所述http-flv子模块添加到live模块之后。如此,就将所述http-flv子模。
请参照图2,图2为应用于图1所示的节点服务器100的一种直播视频转发方法的流程图,以下将对所述方法包括各个步骤进行详细阐述。
步骤S110,接收所述用户终端200发送的视频获取请求,所述视频获取请求用于获取目标直播视频源。
在本实施例中,所述视频获取请求中可以包括所述目标直播视频源的标识信息。
步骤S120,解析所述视频获取请求,得到该视频获取请求的协议类型,并判断该协议是否为预设的第一协议,所述第一协议为开放协议。
在本实施例中,若所述视频获取请求即为rtmp协议,则所述节点服务器100判断为该视频请求不需要进行协议转换,则不执行后续步骤,直接进行直播视频流的转发。
步骤S130,若所述视频获取请求的协议为预设的第一协议,与该用户终端200建立第一协议的直播会话。
在本实施例中,所述节点服务器100先检测所述Nginx-rtmp模块的转换使能标识是否标识为开启状态。
在所述转换使能标识为关闭状态时,则不执行后续进行直播数据流传输协议转换步骤;在所述转换使能标识为开启状态时,与所述用户终端200建立所述第一协议的直播会话。
在本实施例中,所述节点服务器100中针对每个直播视频源预设有直播会话的订阅队列,所述节点服务器100将与所述用户终端200建立的直播会话加入对应的订阅队列等待数据传输。
具体地,所述节点服务器100针对每个所述直播会话申请会话交互上下文ctx,设置交互上下文的句柄为http-flv特有交互上下文,以区分于rtmp协议的上下文。所述节点服务从所述视频获取请求的URL中解析获取对应application对象的名称。然后从全局参数中获取application对象的名称对应的目标直播视频源,例如,根据所述application对象的hash值查找对应的目标直播视频源。若为查找到对应的目标直播视频源,则关闭该直播会话;若找到对应的所述目标视频源,则将所述上下文ctx注册到所述目标直播视频源的分发队列中等待所述目标直播视频源到来。
步骤S140,从所述资源服务器300获取所述目标直播视频源的第二协议的直播数据流,从所述直播数据流中解析获得有效数据流,所述第二协议为非开放协议。
具体地,在本实施例中,所述节点服务器100先检测所述Nginx-rtmp模块的直播数据流接收队列中待接收的直播数据流数量是否超过预设阈值。
当超过所述预设阈值时,舍弃接收到的直播数据流;
当没有超过所述预设阈值时,将接收到的所述直播数据流中rtmp协议相关的数据头去除,采用浅拷贝的方式复制所述直播数据流相关的引用,并添加引用计数,得到有效数据流。
步骤S150,将所述有效数据流通过所述第一协议的直播会话发送给所述用户终端200。
遍历所述订阅队列,将所述有效数据流的发送给所述订阅队列中的直播会话,使所述用户终端200通过所述第一协议的直播会话获得的所述有效数据流。
请参照图4,本实施例还提供一种应用与图1所示节点服务器100的直播视频转发装置110,所述装置包括请求接收模块111、请求解析模块112、会话建立模块113、有效数据获取模块114及发送模块115。
所述请求接收模块111,用于接收所述用户终端200发送的视频获取请求,所述视频获取请求用于获取目标直播视频源。
本实施例中,所述请求接收模块111可用于执行图3所示的步骤S110,关于所述请求接收模块111的具体描述可参对所述步骤S110的描述。
所述请求解析模块112,用于解析所述视频获取请求,得到该视频获取请求的协议类型,并判断该协议是否为预设的第一协议,所述第一协议为开放协议。
本实施例中,所述请求解析模块112可用于执行图3所示的步骤S120,关于所述请求解析模块112的具体描述可参对所述步骤S120的描述。
所述会话建立模块113,用于当所述视频获取请求的协议为预设的第一协议时,与该用户终端200建立第一协议的直播会话。
本实施例中,所述会话建立模块113可用于执行图3所示的步骤S130,关于所述会话建立模块113的具体描述可参对所述步骤S130的描述。
可选地,在本实施例中,所述节点服务器100中预设有用于进行视频转发处理的Nginx-rtmp模块,所述Nginx-rtmp模块包括用于标识直播数据流协议转换功能是否开启的转换使能标识;所述会话建立模块113通过以下方式与该用户终端200建立第一协议的直播会话:
检测所述Nginx-rtmp模块的转换使能标识是否标识为开启状态;
在所述转换使能标识为开启状态时,再与所述用户终端200建立所述第一协议的直播会话。
所述有效数据获取模块114,用于从所述资源服务器300获取所述目标直播视频源的第二协议的直播数据流,从所述直播数据流中解析获得有效数据流,所述第二协议为非开放协议。
本实施例中,所述有效数据获取模块114可用于执行图3所示的步骤S140,关于所所述有效数据获取模块114通过以下方式从所述直播数据流中解析获得有效数据流:
进一地,在本实施例中,检测所述Nginx-rtmp模块的直播数据流接收队列中待接收的直播数据流数量是否超过预设阈值;
当超过所述预设阈值时,舍弃接收到的直播数据流;
当没有超过所述预设阈值时,将接收到的所述直播数据流中rtmp协议相关的数据头去除,采用浅拷贝的方式复制所述直播数据流相关的引用,得到有效数据流。述有效数据获取模块114的具体描述可参对所述步骤S140的描述。
所述发送模块115,用于将所述有效数据流通过所述第一协议的直播会话发送给所述用户终端200。
本实施例中,所述发送模块115可用于执行图3所示的步骤S150,关于所述发送模块115的具体描述可参对所述步骤S150的描述。
可选地,在本实施例中,所述节点服务器100中预设有用于存储已建立的直播会话的订阅队列;所述发送模块115通过以下方式将所述有效数据流通过发送给相应的用户终端200:
遍历所述订阅队列,将所述有效数据流的发送给所述订阅队列中的直播会话,使所述用户终端200通过所述第一协议的直播会话获得的所述有效数据流。
综上所述,本发明提供的直播视频转发方法及装置,通过将接收用户终端200发送的视频获取请求,将接收到的第二协议的直播视频流转换为与所述视频获取请求对应的第一协议的直播视频流。如此,在不改变节点服务从资源服务器300获取直播视频流订阅模式的情况下,实现了直播视频流的传输方式从采用非开放的第二协议向开放的第一协议的转换,降低了用户终端200接收所述直播视频的故障率。
在本申请所提供的实施例中,应该理解到,所揭露的装置和方法,也可以通过其它的方式实现。以上所描述的装置实施例仅仅是示意性的,例如,附图中的流程图和框图显示了根据本发明的多个实施例的装置、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段或代码的一部分,所述模块、程序段或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现方式中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个连续的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或动作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
另外,在本发明各个实施例中的各功能模块可以集成在一起形成一个独立的部分,也可以是各个模块单独存在,也可以两个或两个以上模块集成形成一个独立的部分。
所述功能如果以软件功能模块的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)、磁碟或者光盘等各种可以存储程序代码的介质。
需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。
以上所述,仅为本发明的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应所述以权利要求的保护范围为准。
Claims (10)
1.一种直播视频转发方法,应用于与资源服务器及用户终端通信的节点服务器,其特征在于,所述方法包括:
接收所述用户终端发送的视频获取请求,所述视频获取请求用于获取目标直播视频源;
解析所述视频获取请求,得到该视频获取请求的协议类型,并判断该协议是否为预设的第一协议;其中,所述视频获取请求的协议为所述用户终端期望获取的直播视频流的协议;
若所述视频获取请求的协议为预设的第一协议,与该用户终端建立第一协议的直播会话;
从所述资源服务器获取所述目标直播视频源的第二协议的直播数据流,从所述直播数据流中解析获得有效数据流;
将所述有效数据流通过所述第一协议的直播会话发送给所述用户终端。
2.根据权利要求1所述的方法,其特征在于,所述第一协议包括http协议,所述第二协议包括rtmp协议。
3.根据权利要求2所述的方法,其特征在于,所述节点服务器中预设有用于进行视频转发处理的Nginx-rtmp模块,所述Nginx-rtmp模块包括用于标识直播数据流协议转换功能是否开启的转换使能标识;所述与该用户终端建立第一协议的直播会话的步骤,包括:
检测所述Nginx-rtmp模块的转换使能标识是否标识为开启状态;
在所述转换使能标识为开启状态时,再与所述用户终端建立所述第一协议的直播会话。
4.根据权利要求3所述的方法,其特征在于,所述从所述资源服务器获取所述目标直播视频源的第二协议的直播数据流,从所述直播数据流中解析获得有效数据流的步骤,包括:
检测所述Nginx-rtmp模块的直播数据流接收队列中待接收的直播数据流数量是否超过预设阈值;
当超过所述预设阈值时,舍弃接收到的直播数据流;
当没有超过所述预设阈值时,将接收到的所述直播数据流中rtmp协议相关的数据头去除,采用浅拷贝的方式复制所述直播数据流相关的引用,得到有效数据流。
5.根据权利要求3所述的方法,其特征在于,所述节点服务器中预设有用于存储已建立的直播会话的订阅队列;所述将所述有效数据流通过所述第一协议的直播会话发送给相应的用户终端的步骤,包括:
遍历所述订阅队列,将所述有效数据流发送给所述订阅队列中的直播会话,使所述用户终端通过所述第一协议的直播会话获得所述有效数据流。
6.一种直播视频转发装置,应用于与资源服务器及用户终端通信的节点服务器,其特征在于,所述装置包括:
请求接收模块,用于接收所述用户终端发送的视频获取请求,所述视频获取请求用于获取目标直播视频源;
请求解析模块,用于解析所述视频获取请求,得到该视频获取请求的协议类型,并判断该协议是否为预设的第一协议,所述第一协议为开放协议;其中,所述视频获取请求的协议为所述用户终端期望获取的直播视频流的协议;
会话建立模块,用于当所述视频获取请求的协议为预设的第一协议时,与该用户终端建立第一协议的直播会话;
有效数据获取模块,用于从所述资源服务器获取所述目标直播视频源的第二协议的直播数据流,从所述直播数据流中解析获得有效数据流,所述第二协议为非开放协议;
发送模块,用于将所述有效数据流通过所述第一协议的直播会话发送给所述用户终端。
7.根据权利要求6所述的装置,其特征在于,所述第一协议包括http协议,所述第二协议包括rtmp协议。
8.根据权利要求7所述的装置,其特征在于,所述节点服务器中预设有用于进行视频转发处理的Nginx-rtmp模块,所述Nginx-rtmp模块包括用于标识直播数据流协议转换功能是否开启的转换使能标识;所述会话建立模块检测所述Nginx-rtmp模块的转换使能标识是否标识为开启状态,在所述转换使能标识为开启状态时,再与所述用户终端建立所述第一协议的直播会话。
9.根据权利要求8所述的装置,其特征在于,所述有效数据获取模块通过以下方式从所述直播数据流中解析获得有效数据流:
检测所述Nginx-rtmp模块的直播数据流接收队列中待接收的直播数据流数量是否超过预设阈值;
当超过所述预设阈值时,舍弃接收到的直播数据流;
当没有超过所述预设阈值时,将接收到的所述直播数据流中rtmp协议相关的数据头去除,采用浅拷贝的方式复制所述直播数据流相关的引用,得到有效数据流。
10.根据权利要求8所述的装置,其特征在于,所述节点服务器中预设有用于存储已建立的直播会话的订阅队列;所述发送模块遍历所述订阅队列,将所述有效数据流发送给所述订阅队列中的直播会话,使所述用户终端通过所述第一协议的直播会话获得所述有效数据流,实现将所述有效数据流通过发送给相应的用户终端。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710849241.7A CN107592554B (zh) | 2017-09-20 | 2017-09-20 | 直播视频转发方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710849241.7A CN107592554B (zh) | 2017-09-20 | 2017-09-20 | 直播视频转发方法及装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN107592554A CN107592554A (zh) | 2018-01-16 |
CN107592554B true CN107592554B (zh) | 2019-08-02 |
Family
ID=61046962
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201710849241.7A Active CN107592554B (zh) | 2017-09-20 | 2017-09-20 | 直播视频转发方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN107592554B (zh) |
Families Citing this family (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110113564B (zh) * | 2019-03-25 | 2021-08-13 | 视联动力信息技术股份有限公司 | 一种数据获取方法和视联网系统 |
CN112019563B (zh) * | 2020-09-11 | 2023-04-07 | 成都运达科技股份有限公司 | 一种视频数据转发传输系统及方法 |
CN112738202B (zh) * | 2020-12-25 | 2023-05-26 | 广州虎牙科技有限公司 | 一种数据处理方法和相关装置以及存储介质 |
CN113746755B (zh) * | 2021-07-30 | 2023-10-20 | 咪咕文化科技有限公司 | 数据处理方法、装置、设备及计算机可读存储介质 |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101242538A (zh) * | 2008-03-18 | 2008-08-13 | 华为技术有限公司 | 一种码流解码方法和装置 |
CN105898392A (zh) * | 2015-11-24 | 2016-08-24 | 乐视云计算有限公司 | 在线直播视频播放器及方法 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8243924B2 (en) * | 2007-06-29 | 2012-08-14 | Google Inc. | Progressive download or streaming of digital media securely through a localized container and communication protocol proxy |
-
2017
- 2017-09-20 CN CN201710849241.7A patent/CN107592554B/zh active Active
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101242538A (zh) * | 2008-03-18 | 2008-08-13 | 华为技术有限公司 | 一种码流解码方法和装置 |
CN105898392A (zh) * | 2015-11-24 | 2016-08-24 | 乐视云计算有限公司 | 在线直播视频播放器及方法 |
Also Published As
Publication number | Publication date |
---|---|
CN107592554A (zh) | 2018-01-16 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN107592554B (zh) | 直播视频转发方法及装置 | |
EP2383941B1 (en) | Client terminal, method and system for downloading streaming media | |
US11212334B2 (en) | Mechanisms to support adaptive constrained application protocol (CoAP) streaming for Internet of Things (IoT) systems | |
CN110049353B (zh) | 用于在广播系统中传输多媒体数据的装置及方法 | |
AU2012321424A1 (en) | Apparatus and method for transmitting multimedia data in hybrid network | |
US8711869B2 (en) | Message transfer apparatus, output method, and computer program product | |
CN106550241A (zh) | 视频业务识别系统及虚拟化部署方法 | |
EP3357208B1 (en) | Pcc control of http adaptive bit rate video streaming protocols | |
CN104040989B (zh) | 网关,及相应的方法、计算机程序和存储装置 | |
JP2007507942A (ja) | Ipネットワークでdvbサービスを伝送する方法及び装置 | |
US10264299B2 (en) | Method and apparatus for transmitting and receiving media data in multimedia system | |
WO2014169812A1 (zh) | 报文的转发处理方法及装置 | |
CN110166518B (zh) | 会话信息的传输方法、装置、存储介质及电子装置 | |
CN108881148B (zh) | 一种数据获取方法和装置 | |
WO2009052727A1 (fr) | Procédé d'envoi, procédé de traitement, système de communication et dispositif pour des informations de flux de données | |
WO2014148613A1 (ja) | ネットワーク統計情報の提供システム、ネットワーク統計情報の提供方法及びプログラム | |
KR20150112894A (ko) | Mmt 에셋 전달 특성 시그널링 메시지의 구성 방법 | |
CN111031090A (zh) | 数据处理方法、装置、电子设备及可读存储介质 | |
CN106506578B (zh) | 数据分享系统及方法 | |
US11362927B2 (en) | Methods, switch and frame capture managing module for managing ethernet frames | |
CN110839011A (zh) | 监控资源信息的上报方法和装置 | |
CN114095308B (zh) | 多媒体会议质量的增强方法、装置、设备及存储介质 | |
WO2022262574A1 (zh) | 切片信息的确定方法、装置、存储介质及电子装置 | |
US20190349610A1 (en) | Data distribution system, data distribution method, marker, filter and program | |
CN117440193A (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 | ||
TR01 | Transfer of patent right |
Effective date of registration: 20240108 Address after: 721000, Shop 9, 1st Floor, Building 3, No. 11 Daqing Road, Administrative West Road Community, Wolongsi Street Office, Jintai District, Baoji City, Shaanxi Province Patentee after: Baoji Ziruixiang Network Information Technology Co.,Ltd. Address before: 430000 East Lake Development Zone, Wuhan City, Hubei Province, No. 1 Software Park East Road 4.1 Phase B1 Building 11 Building Patentee before: WUHAN DOUYU NETWORK TECHNOLOGY Co.,Ltd. |
|
TR01 | Transfer of patent right |