CN108521421B - 一种转码任务的处理方法、系统及任务管理服务器 - Google Patents

一种转码任务的处理方法、系统及任务管理服务器 Download PDF

Info

Publication number
CN108521421B
CN108521421B CN201810312228.2A CN201810312228A CN108521421B CN 108521421 B CN108521421 B CN 108521421B CN 201810312228 A CN201810312228 A CN 201810312228A CN 108521421 B CN108521421 B CN 108521421B
Authority
CN
China
Prior art keywords
transcoding
task
server
audio
streaming media
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.)
Expired - Fee Related
Application number
CN201810312228.2A
Other languages
English (en)
Other versions
CN108521421A (zh
Inventor
荆睿
马良
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Wangsu Science and Technology Co Ltd
Original Assignee
Wangsu Science and Technology Co Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Wangsu Science and Technology Co Ltd filed Critical Wangsu Science and Technology Co Ltd
Priority to CN201810312228.2A priority Critical patent/CN108521421B/zh
Priority to US16/094,088 priority patent/US10645140B2/en
Priority to PCT/CN2018/086182 priority patent/WO2019196158A1/zh
Priority to EP18863796.1A priority patent/EP3579560A4/en
Publication of CN108521421A publication Critical patent/CN108521421A/zh
Application granted granted Critical
Publication of CN108521421B publication Critical patent/CN108521421B/zh
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/60Network streaming of media packets
    • H04L65/75Media network packet handling
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/60Network structure or processes for video distribution between server and client or between remote clients; Control signalling between clients, server and network components; Transmission of management data between server and client, e.g. sending from server to client commands for recording incoming content stream; Communication details between server and client 
    • H04N21/63Control signaling related to video distribution between client, server and network components; Network processes for video distribution between server and clients or between remote clients, e.g. transmitting basic layer and enhancement layers over different transmission paths, setting up a peer-to-peer communication via Internet between remote STB's; Communication protocols; Addressing
    • H04N21/647Control signaling between network components and server or clients; Network processes for video distribution between server and clients, e.g. controlling the quality of the video stream, by dropping packets, protecting content from unauthorised alteration within the network, monitoring of network load, bridging between two different networks, e.g. between IP and wireless
    • H04N21/64723Monitoring of network processes or resources, e.g. monitoring of network load
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/60Network streaming of media packets
    • H04L65/61Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/60Network streaming of media packets
    • H04L65/70Media network packetisation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/60Network streaming of media packets
    • H04L65/75Media network packet handling
    • H04L65/762Media network packet handling at the source 
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/80Responding to QoS
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/40Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using video transcoding, i.e. partial or full decoding of a coded input stream followed by re-encoding of the decoded output stream
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/234Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs
    • H04N21/2343Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs involving reformatting operations of video signals for distribution or compliance with end-user requests or end-user device requirements
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing 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/44Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream or rendering scenes according to encoded video stream scene graphs
    • H04N21/4402Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream or rendering scenes according to encoded video stream scene graphs involving reformatting operations of video signals for household redistribution, storage or real-time display
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/40Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass for recovering from a failure of a protocol instance or entity, e.g. service redundancy protocols, protocol state redundancy or protocol service redirection

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Computer Security & Cryptography (AREA)
  • Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)
  • Compression Or Coding Systems Of Tv Signals (AREA)

Abstract

本发明公开了一种转码任务的处理方法、系统及任务管理服务器,其中,所述方法包括:接收流媒体服务器创建的转码任务,并将所述转码任务调度至转码服务器处,以使得所述转码服务器执行所述转码任务;检测所述转码任务在所述转码服务器中的执行状态,并当检测到所述转码任务终止时,向所述流媒体服务器反馈表征转码终止的提示信息,以使得所述流媒体服务器判断是否重新建立所述转码任务;若所述流媒体服务器重新建立所述转码任务,接收所述流媒体服务器发来的重新建立的所述转码任务,并将重新建立的所述转码任务调度至所述转码服务器处,以使得所述转码服务器重新执行所述转码任务。本申请提供的技术方案,能够及时完成解码过程。

Description

一种转码任务的处理方法、系统及任务管理服务器
技术领域
本发明涉及互联网技术领域,特别涉及一种转码任务的处理方法、系统及任务管理服务器。
背景技术
随着互联网技术的不断发展,网络中的音视频资源也越来越多。当前,原始的音视频资源可以在编码之后,发送至流媒体服务器中。流媒体服务器中的音视频资源在提供给用户观看之前,可以先通过转码服务器将音视频资源转换为用户端能够识别的格式。
转码服务器在对音视频资源转码的过程中,可能会出现各种异常情况,而导致转码失败。例如,在解码连续失败、编码连续失败等情况下,转码服务器便无法正常完成音视频解码的过程,使得用户无法及时观看到对应的音视频资源。
发明内容
本申请的目的在于提供一种转码任务的处理方法、系统及任务管理服务器,能够及时完成解码过程。
为实现上述目的,本申请一方面提供一种转码任务的处理方法,所述方法包括:接收流媒体服务器创建的转码任务,并将所述转码任务调度至转码服务器处,以使得所述转码服务器执行所述转码任务;检测所述转码任务在所述转码服务器中的执行状态,并当检测到所述转码任务终止时,向所述流媒体服务器反馈表征转码终止的提示信息,以使得所述流媒体服务器判断是否重新建立所述转码任务;若所述流媒体服务器重新建立所述转码任务,接收所述流媒体服务器发来的重新建立的所述转码任务,并将重新建立的所述转码任务调度至所述转码服务器处,以使得所述转码服务器重新执行所述转码任务。
为实现上述目的,本申请另一方面还提供一种任务管理服务器,所述任务管理服务器包括存储器和处理器,所述存储器中存储计算机程序,所述计算机程序被所述处理器执行时,实现上述的方法。
为实现上述目的,本申请另一方面还提供一种转码任务的处理系统,所述系统包括流媒体服务器、任务管理服务器以及转码服务器,其中:所述流媒体服务器,用于创建转码任务,并将创建的所述转码任务发送至所述任务管理服务器;在接收到所述任务管理服务器发来的表征转码终止的提示信息时,判断是否重新建立所述转码任务;所述任务管理服务器,用于接收所述流媒体服务器创建的所述转码任务,并将所述转码任务调度至所述转码服务器处;检测所述转码任务在所述转码服务器中的执行状态,并当检测到所述转码任务终止时,向所述流媒体服务器反馈表征转码终止的提示信息;若所述流媒体服务器重新建立所述转码任务,接收所述流媒体服务器发来的重新建立的所述转码任务,并将重新建立的所述转码任务调度至所述转码服务器处;所述转码服务器,用于执行所述任务管理服务器调度来的转码任务。
由上可见,本申请提供的技术方案中,可以通过任务管理服务器,对流媒体服务器创建的转码任务进行调度和管理,并可以检测转码任务在转码服务器中的执行状态。具体地,流媒体服务器可以创建针对某个音视频流的转码任务,该转码任务被发送至任务管理服务器后,任务管理服务器可以根据负载均衡的策略,将转码任务调度至某个转码服务器处。这样,转码服务器可以根据该转码任务,从流媒体服务器中获取待转码的音视频流,并开始执行转码任务。在转码过程中,当转码任务终止时,任务管理服务器可以检测到该终止行为,并向流媒体服务器汇报转码任务终止的提示信息。这样,流媒体服务器可以通过检测该转码任务的音视频流的连接是否断开,从而判断是否需要重新建立该音视频流的转码任务。例如,如果音视频流的连接没有断开,表示当前的任务终止属于异常情况,可以重新建立该音视频流的转码任务,从而继续转码过程。如果音视频流的连接断开,则表示转码任务属于正常终止,则无须重新建立转码任务。由上可见,本申请提供的技术方案,能够及时检测并恢复发生异常的转码任务,从而保证音视频流能够及时完成解码过程。
附图说明
为了更清楚地说明本发明实施例中的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本发明实施例中转码任务的处理系统的架构示意图;
图2是本发明实施例中转码任务的处理方法流程图;
图3是本发明实施例中转码任务的处理方法的交互示意图;
图4是本发明实施例中任务管理服务器的结构示意图;
图5是本发明实施例中计算机终端的结构示意图。
具体实施方式
为使本发明的目的、技术方案和优点更加清楚,下面将结合附图对本发明实施方式作进一步地详细描述。
实施例一
本申请提供一种转码任务的处理方法,所述方法可以应用于任务管理服务器中。请参阅图1,在现有的系统架构的基础上,可以增设上述的任务管理服务器。所述任务管理服务器可以分别与流媒体服务器和转码服务器连接。所述流媒体服务器中可以存储音视频数据,所述转码服务器可以从所述流媒体服务器中获取音视频数据,并对音视频数据进行解码。
请参阅图2和图3,所述转码任务的处理方法可以包括以下步骤。
S1:接收流媒体服务器创建的转码任务,并将所述转码任务调度至转码服务器处,以使得所述转码服务器执行所述转码任务。
在本实施方式中,所述流媒体服务器可以创建转码任务,该转码任务中可以包含音视频标识,该音视频标识可以指向所述流媒体服务器中的音视频流。举例来说,所述流媒体服务器可以接收主播客户端发来的直播数据,这些直播数据可以是通过对主播的麦克风、摄像头采集的原始音视频数据处理而来。具体地,主播的麦克风、摄像头采集到原始的音视频数据之后,可以对该原始的音视频数据进行编码,编码后的音视频数据通过流媒体协议封装之后,可以按照音视频流被推送至所述流媒体服务器。这样,当用户客户端想要观看某个主播的音视频流时,便可以向流媒体服务器发起数据获取请求,流媒体服务器从而可以针对该数据获取请求对应的音视频流创建转码任务。
在本实施方式中,流媒体服务器创建了所述转码任务之后,可以将所述转码任务发送至所述任务管理服务器。所述任务管理服务器可以负责对转码任务进行调度和监控,从而保证转码过程能够完成。具体地,所述任务管理服务器可以与多个转码服务器建立连接,在接收到流媒体服务器发来的转码任务后,可以根据各个转码服务器当前的负载,通过负载均衡的方式,将所述转码任务调度至其中一个转码服务器中。
在本实施方式中,所述转码服务器接收到任务管理服务器调度来的转码任务之后,便可以执行所述转码任务。具体地,所述转码服务器可以针对接收到的转码任务,开启转码进程。通过该转码进程,可以处理与所述转码任务相关的一系列操作。例如,通过该转码进程,转码服务器可以从所述转码任务中提取出音视频标识,并向流媒体服务器发起包含该音视频标识的资源获取请求,从而可以从流媒体服务群中拉取所述音视频标识指向的音视频流。在拉取到对应的音视频流之后,转码服务器便可以通过该转码进程,对拉取的音视频流进行转码。
在本实施方式中,转码的过程可以包括多个步骤,具体地,转码服务器可以按照音视频流的编码方式,对应地对该音视频流进行解码,解码得到的原始音视频流可以通过滤镜进行处理。所述滤镜可以对解码得到的原始音视频流进行视频分辨率、音频采样率等参数的调整,从而使得调整后的音视频流能够符合后续编码的要求。这样,滤镜输出的音视频流可以根据用户客户端所支持的编码方式进行编码,编码后的音视频流便可以推送给用户客户端,从而完成整个转码的过程。
S3:检测所述转码任务在所述转码服务器中的执行状态,并当检测到所述转码任务终止时,向所述流媒体服务器反馈表征转码终止的提示信息,以使得所述流媒体服务器判断是否重新建立所述转码任务。
在本实施方式中,转码任务在转码服务器中执行时,可能因为各种原因异常终止。鉴于此,任务管理服务器在将转码任务调度至所述转码服务器之后,可以创建状态监控进程,并通过所述状态监控进程,检测所述转码服务器中用于执行所述转码任务的转码进程是否退出。这样,任务管理服务器可以检测所述转码任务在所述转码服务器中的执行状态。
在本实施方式中,若检测到所述用于执行所述转码任务的转码进程退出时,则表征所述转码任务终止。此时,任务管理服务器可以向所述流媒体服务器反馈表征转码终止的提示信息。该提示信息中同样可以包括音视频标识,这样,所述流媒体服务器从而可以获知哪个音视频流的转码任务被终止。所述流媒体服务器在接收到该提示信息后,可以根据其中的音视频标识查询到被终止执行转码的音视频流。此时,流媒体服务器可以检测与所述转码服务器之间所述转码任务指向的音视频流的连接是否断开。正常情况下,当转码服务器开始执行转码任务时,需要与流媒体服务器建立连接,并通过该连接获取需要转码的音视频流,在转码正常结束之后,该连接才会被断开。而如果转码异常终止,该连接会依然保持。这样,若该连接未断开,表示转码任务是因为出现异常而终止的,此时,流媒体服务器可以重新建立指向所述音视频流的所述转码任务,以重新对该音视频流进行转码。若该连接已断开,表示转码任务是正常结束,此时可以结束指向所述音视频流的所述转码任务。
S5:若所述流媒体服务器重新建立所述转码任务,接收所述流媒体服务器发来的重新建立的所述转码任务,并将重新建立的所述转码任务调度至所述转码服务器处,以使得所述转码服务器重新执行所述转码任务。
在本实施方式中,如果流媒体服务器判定当前的转码任务为异常终止,可以重新建立该转码任务。该重新建立的转码任务同样可以被发送至任务管理服务器,并通过该任务管理服务器调度至所述转码服务器中,以通过所述转码服务器重新对待转码的音视频流进行转码。
在本实施方式中,所述转码服务器将音视频流转码之后,可以将转码结果通过一个个数据包发送给直播服务器,直播服务器从而可以将转码后的音视频流发送给用户客户端。在发送数据包之后,转码服务器可以将发送的数据包的数据流量上传至所述任务管理服务器。这样,所述任务管理服务器可以将接收的所述数据流量写入日志中,以统计转码服务器向直播服务器发送的数据流量。
在一个实施方式中,当某个音视频流不再被用户观看,或者该音视频流已经播放结束之后,流媒体服务器可以向任务管理服务器发送任务取消指令,该任务取消指令表明当前的转码任务可以终止。这样,任务管理服务器可以将该任务取消指令转发给所述转码服务器,转码服务器从而可以取消用于执行所述转码任务的转码进程,同时,任务管理服务器也可以取消用于监控所述转码进程的状态监控进程。
在一个实施方式中,转码服务器在执行转码任务时,可以通过多种方式检测转码过程中的异常,并可以尝试将转码过程恢复正常。具体地,转码服务器从流媒体服务器中拉取的音视频流的输入路数,理论上应该与转码得到的音视频流的输出路数相一致。然而,在某些转码场景中,转码过程可能存在异常,从而导致输出路数与输入路数不一致。例如,针对输入路数中的音频流,转码服务器没有正常完成转码,从而使得输出路数中缺少了音频流。在这种情况下,转码得到的音视频流是存在缺陷的,因此,当转码服务器检测到待转码的音视频流的输入路数与完成转码的音视频流的输出路数不一致时,表明转码过程存在异常,可以退出当前的转码进程。后续任务管理服务器检测到本次异常后,可以通知流媒体服务器,从而重新创建转码任务。
此外,转码服务器还可以对连续转码失败的情况进行控制。具体地,转码服务器可以检测连续转码失败的时长,若待转码的音视频流在指定时长内持续转码失败,表示转码过程无法正常执行下去,此时可以退出当前的转码进程,表示转码过程异常终止。
在另一个实施方式中,由于网络传输状态或者原始音视频流发生改变等情况,导致转码服务器从流媒体服务器处前后两次拉取的音视频流的配置参数不一致,如果采用相同的编码方式对配置参数不一致的数据进行编码,那么会导致编码后的音视频流存在异常。鉴于此,转码服务器在拉取到当前待转码的音视频流后,可以从当前待转码的音视频流中解析出配置参数,并将当前解析出的所述配置参数与上一次解析出的配置参数进行对比。所述配置参数可以是用于描述视频宽高、视频帧率、音视频压缩格式、音频采样率等信息的参数。所述配置参数可以记录于音视频流的metadata(元数据)、AVC header(AdvancedVideo Coding header,高级视频编码文件头)或者AAC header(Advanced Audio Codingheader,高级音频编码文件头)中。这样,若前后两次解析出的配置参数不一致,则表明当前的音视频流相比于上一次拉取的音视频流发生了变化,此时,可以读取解码器和滤镜中当前缓存的音视频数据,并将读取出的所述音视频数据进行编码后发送至直播服务器。然后,再重新初始化所述解码器和所述滤镜,并通过重新初始化后的解码器和滤镜处理所述待转码的音视频流。这样,具备不同配置参数的音视频流可以基于不同的初始化结果进行处理,从而保证不同的音视频流均可以完成正常的转码过程。
实施例二
请参阅图4,本申请还提供一种任务管理服务器,所述任务管理服务器包括存储器和处理器,所述存储器中存储计算机程序,所述计算机程序被所述处理器执行时,可以实现上述实施例一种描述的各个方法步骤。
在本实施方式中,所述存储器可以包括用于存储信息的物理装置,通常是将信息数字化后再以利用电、磁或者光学等方法的媒体加以存储。本实施方式所述的存储器又可以包括:利用电能方式存储信息的装置,如RAM、ROM等;利用磁能方式存储信息的装置,如硬盘、软盘、磁带、磁芯存储器、磁泡存储器、U盘;利用光学方式存储信息的装置,如CD或DVD。当然,还有其他方式的计算机存储介质,例如量子存储器、石墨烯存储器等等。
在本实施方式中,所述处理器可以按任何适当的方式实现。例如,所述处理器可以采取例如微处理器或处理器以及存储可由该(微)处理器执行的计算机可读程序代码(例如软件或固件)的计算机可读介质、逻辑门、开关、专用集成电路(Application SpecificIntegrated Circuit,ASIC)、可编程逻辑控制器和嵌入微控制器的形式等等。
本说明书实施方式提供的任务管理服务器,其本身所实现的具体功能,可以与本说明书中的前述方法实施方式相对照解释,并能够达到前述方法实施方式的技术效果,这里便不再赘述。
实施例三
本申请还提供一种转码任务的处理系统,请参阅图1,所述系统包括流媒体服务器、任务管理服务器以及转码服务器,其中:
所述流媒体服务器,用于创建转码任务,并将创建的所述转码任务发送至所述任务管理服务器;在接收到所述任务管理服务器发来的表征转码终止的提示信息时,判断是否重新建立所述转码任务;
所述任务管理服务器,用于接收所述流媒体服务器创建的所述转码任务,并将所述转码任务调度至所述转码服务器处;检测所述转码任务在所述转码服务器中的执行状态,并当检测到所述转码任务终止时,向所述流媒体服务器反馈表征转码终止的提示信息;若所述流媒体服务器重新建立所述转码任务,接收所述流媒体服务器发来的重新建立的所述转码任务,并将重新建立的所述转码任务调度至所述转码服务器处;
所述转码服务器,用于执行所述任务管理服务器调度来的转码任务。
在一个实施方式中,所述任务管理服务器包括:
进程创建单元,用于创建状态监控进程,并通过所述状态监控进程,检测所述转码服务器中用于执行所述转码任务的转码进程是否退出;相应地,当检测到所述用于执行所述转码任务的转码进程退出时,表征所述转码任务终止。
在一个实施方式中,所述流媒体服务器包括:
连接检测单元,用于在接收到所述提示信息后,检测与所述转码服务器之间所述转码任务指向的音视频流的连接是否断开;
判断单元,用于判定若未断开,重新建立指向所述音视频流的所述转码任务;若断开,结束指向所述音视频流的所述转码任务。
在一个实施方式中,所述转码服务器包括:
路数对比单元,用于检测待转码的音视频流的输入路数以及完成转码的音视频流的输出路数,并对比所述输入路数和所述输出路数;
进程退出单元,用于若所述输入路数和所述输出路数不一致,退出当前的转码进程。
在一个实施方式中,所述转码服务器包括:
配置参数处理单元,用于从当前待转码的音视频流中解析出配置参数,并将当前解析出的所述配置参数与上一次解析出的配置参数进行对比,若两者不一致,读取解码器和滤镜中当前缓存的音视频数据,并将读取出的所述音视频数据进行编码后发送至直播服务器;
初始化单元,用于重新初始化所述解码器和所述滤镜,并通过重新初始化后的解码器和滤镜处理所述待转码的音视频流。
请参阅图5,在本申请中,上述实施例中的技术方案可以应用于如图5所示的计算机终端10上。计算机终端10可以包括一个或多个(图中仅示出一个)处理器102(处理器102可以包括但不限于微处理器MCU或可编程逻辑器件FPGA等的处理装置)、用于存储数据的存储器104、以及用于通信功能的传输模块106。本领域普通技术人员可以理解,图5所示的结构仅为示意,其并不对上述电子装置的结构造成限定。例如,计算机终端10还可包括比图5中所示更多或者更少的组件,或者具有与图5所示不同的配置。
存储器104可用于存储应用软件的软件程序以及模块,处理器102通过运行存储在存储器104内的软件程序以及模块,从而执行各种功能应用以及数据处理。存储器104可包括高速随机存储器,还可包括非易失性存储器,如一个或者多个磁性存储装置、闪存、或者其他非易失性固态存储器。在一些实例中,存储器104可进一步包括相对于处理器102远程设置的存储器,这些远程存储器可以通过网络连接至计算机终端10。上述网络的实例包括但不限于互联网、企业内部网、局域网、移动通信网及其组合。
传输装置106用于经由一个网络接收或者发送数据。上述的网络具体实例可包括计算机终端10的通信供应商提供的无线网络。在一个实例中,传输装置106包括一个网络适配器(Network Interface Controller,NIC),其可通过基站与其他网络设备相连从而可与互联网进行通讯。在一个实例中,传输装置106可以为射频(Radio Frequency,RF)模块,其用于通过无线方式与互联网进行通讯。
由上可见,本申请提供的技术方案中,可以通过任务管理服务器,对流媒体服务器创建的转码任务进行调度和管理,并可以检测转码任务在转码服务器中的执行状态。具体地,流媒体服务器可以创建针对某个音视频流的转码任务,该转码任务被发送至任务管理服务器后,任务管理服务器可以根据负载均衡的策略,将转码任务调度至某个转码服务器处。这样,转码服务器可以根据该转码任务,从流媒体服务器中获取待转码的音视频流,并开始执行转码任务。在转码过程中,当转码任务终止时,任务管理服务器可以检测到该终止行为,并向流媒体服务器汇报转码任务终止的提示信息。这样,流媒体服务器可以通过检测该转码任务的音视频流的连接是否断开,从而判断是否需要重新建立该音视频流的转码任务。例如,如果音视频流的连接没有断开,表示当前的任务终止属于异常情况,可以重新建立该音视频流的转码任务,从而继续转码过程。如果音视频流的连接断开,则表示转码任务属于正常终止,则无须重新建立转码任务。由上可见,本申请提供的技术方案,能够及时检测并恢复发生异常的转码任务,从而保证音视频流能够及时完成解码过程。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到各实施方式可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件。基于这样的理解,上述技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品可以存储在计算机可读存储介质中,如ROM/RAM、磁碟、光盘等,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行各个实施例或者实施例的某些部分所述的方法。
以上所述仅为本发明的较佳实施例,并不用以限制本发明,凡在本发明的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。

Claims (15)

1.一种转码任务的处理方法,其特征在于,所述方法包括:
接收流媒体服务器创建的转码任务,并将所述转码任务调度至转码服务器处,以使得所述转码服务器执行所述转码任务;
检测所述转码任务在所述转码服务器中的执行状态,并当检测到所述转码任务终止时,向所述流媒体服务器反馈表征转码终止的提示信息,以使得所述流媒体服务器判断是否重新建立所述转码任务;其中,若检测到所述转码任务终止,并且所述流媒体服务器与所述转码服务器之间所述转码任务指向的音视频流的连接未断开的情况下,重新建立指向所述音视频流的转码任务;
若所述流媒体服务器重新建立所述转码任务,接收所述流媒体服务器发来的重新建立的所述转码任务,并将重新建立的所述转码任务调度至所述转码服务器处,以使得所述转码服务器重新执行所述转码任务。
2.根据权利要求1所述的方法,其特征在于,所述转码任务中包含音视频标识;相应地,所述转码服务器执行所述转码任务包括:
所述转码服务器开启转码进程,并通过所述转码进程从所述流媒体服务器中拉取所述音视频标识指向的音视频流;
所述转码服务器通过所述转码进程对拉取的所述音视频流进行转码。
3.根据权利要求1或2所述的方法,其特征在于,检测所述转码任务在所述转码服务器中的执行状态包括:
创建状态监控进程,并通过所述状态监控进程,检测所述转码服务器中用于执行所述转码任务的转码进程是否退出;
相应地,当检测到所述用于执行所述转码任务的转码进程退出时,表征所述转码任务终止。
4.根据权利要求1所述的方法,其特征在于,所述流媒体服务器判断是否重新建立所述转码任务包括:
所述流媒体服务器在接收到所述提示信息后,检测与所述转码服务器之间所述转码任务指向的音视频流的连接是否断开;
若未断开,重新建立指向所述音视频流的所述转码任务;若断开,结束指向所述音视频流的所述转码任务。
5.根据权利要求1所述的方法,其特征在于,在将所述转码任务调度至转码服务器处之后,所述方法还包括:
接收所述转码服务器上传的数据流量,并将接收的所述数据流量写入日志中;其中,所述数据流量用于表征所述转码服务器在执行所述转码任务时,向直播服务器输出的各个数据包的数据流量。
6.根据权利要求1所述的方法,其特征在于,所述方法还包括:
接收所述流媒体服务器发来的任务取消指令,并将所述任务取消指令转发至所述转码服务器处,以使得所述转码服务器取消用于执行所述转码任务的转码进程。
7.根据权利要求1所述的方法,其特征在于,所述转码服务器执行所述转码任务时,所述方法还包括:
所述转码服务器检测待转码的音视频流的输入路数以及完成转码的音视频流的输出路数,并对比所述输入路数和所述输出路数;
若所述输入路数和所述输出路数不一致,退出当前的转码进程。
8.根据权利要求1所述的方法,其特征在于,所述转码服务器执行所述转码任务时,所述方法还包括:
若待转码的音视频流在指定时长内持续转码失败,退出当前的转码进程。
9.根据权利要求1所述的方法,其特征在于,所述转码服务器执行所述转码任务时,所述方法还包括:
从当前待转码的音视频流中解析出配置参数,并将当前解析出的所述配置参数与上一次解析出的配置参数进行对比,若两者不一致,读取解码器和滤镜中当前缓存的音视频数据,并将读取出的所述音视频数据进行编码后发送至直播服务器;
重新初始化所述解码器和所述滤镜,并通过重新初始化后的解码器和滤镜处理所述待转码的音视频流。
10.一种任务管理服务器,其特征在于,所述任务管理服务器包括存储器和处理器,所述存储器中存储计算机程序,所述计算机程序被所述处理器执行时,实现如权利要求1至9中任一权利要求所述的方法。
11.一种转码任务的处理系统,其特征在于,所述系统包括流媒体服务器、任务管理服务器以及转码服务器,其中:
所述流媒体服务器,用于创建转码任务,并将创建的所述转码任务发送至所述任务管理服务器;在接收到所述任务管理服务器发来的表征转码终止的提示信息时,判断是否重新建立所述转码任务;
所述任务管理服务器,用于接收所述流媒体服务器创建的所述转码任务,并将所述转码任务调度至所述转码服务器处;检测所述转码任务在所述转码服务器中的执行状态,并当检测到所述转码任务终止时,向所述流媒体服务器反馈表征转码终止的提示信息;若所述流媒体服务器重新建立所述转码任务,接收所述流媒体服务器发来的重新建立的所述转码任务,并将重新建立的所述转码任务调度至所述转码服务器处;其中,若检测到所述转码任务终止,并且所述流媒体服务器与所述转码服务器之间所述转码任务指向的音视频流的连接未断开的情况下,重新建立指向所述音视频流的转码任务;
所述转码服务器,用于执行所述任务管理服务器调度来的转码任务。
12.根据权利要求11所述的系统,其特征在于,所述任务管理服务器包括:
进程创建单元,用于创建状态监控进程,并通过所述状态监控进程,检测所述转码服务器中用于执行所述转码任务的转码进程是否退出;相应地,当检测到所述用于执行所述转码任务的转码进程退出时,表征所述转码任务终止。
13.根据权利要求11所述的系统,其特征在于,所述流媒体服务器包括:
连接检测单元,用于在接收到所述提示信息后,检测与所述转码服务器之间所述转码任务指向的音视频流的连接是否断开;
判断单元,用于判定若未断开,重新建立指向所述音视频流的所述转码任务;若断开,结束指向所述音视频流的所述转码任务。
14.根据权利要求11所述的系统,其特征在于,所述转码服务器包括:
路数对比单元,用于检测待转码的音视频流的输入路数以及完成转码的音视频流的输出路数,并对比所述输入路数和所述输出路数;
进程退出单元,用于若所述输入路数和所述输出路数不一致,退出当前的转码进程。
15.根据权利要求11所述的系统,其特征在于,所述转码服务器包括:
配置参数处理单元,用于从当前待转码的音视频流中解析出配置参数,并将当前解析出的所述配置参数与上一次解析出的配置参数进行对比,若两者不一致,读取解码器和滤镜中当前缓存的音视频数据,并将读取出的所述音视频数据进行编码后发送至直播服务器;
初始化单元,用于重新初始化所述解码器和所述滤镜,并通过重新初始化后的解码器和滤镜处理所述待转码的音视频流。
CN201810312228.2A 2018-04-09 2018-04-09 一种转码任务的处理方法、系统及任务管理服务器 Expired - Fee Related CN108521421B (zh)

Priority Applications (4)

Application Number Priority Date Filing Date Title
CN201810312228.2A CN108521421B (zh) 2018-04-09 2018-04-09 一种转码任务的处理方法、系统及任务管理服务器
US16/094,088 US10645140B2 (en) 2018-04-09 2018-05-09 Method for processing transcoding task, system and task management server
PCT/CN2018/086182 WO2019196158A1 (zh) 2018-04-09 2018-05-09 一种转码任务的处理方法、系统及任务管理服务器
EP18863796.1A EP3579560A4 (en) 2018-04-09 2018-05-09 TRANSCODING TASK PROCESSING METHOD AND SYSTEM, AND TASK MANAGEMENT SERVER

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201810312228.2A CN108521421B (zh) 2018-04-09 2018-04-09 一种转码任务的处理方法、系统及任务管理服务器

Publications (2)

Publication Number Publication Date
CN108521421A CN108521421A (zh) 2018-09-11
CN108521421B true CN108521421B (zh) 2019-11-12

Family

ID=63432187

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201810312228.2A Expired - Fee Related CN108521421B (zh) 2018-04-09 2018-04-09 一种转码任务的处理方法、系统及任务管理服务器

Country Status (3)

Country Link
EP (1) EP3579560A4 (zh)
CN (1) CN108521421B (zh)
WO (1) WO2019196158A1 (zh)

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109963169B (zh) * 2019-04-04 2021-10-19 网宿科技股份有限公司 一种转码方法、服务器和计算机可读存储介质
CN110381340A (zh) * 2019-06-10 2019-10-25 广州虎牙信息科技有限公司 视频文件处理系统
CN113778856B (zh) * 2021-07-27 2023-12-08 浙江大学 基于流媒体语义服务器的app检测方法和系统
CN113992537B (zh) * 2021-10-26 2023-06-20 上海网达软件股份有限公司 在线转码的日志管理方法、系统、设备及存储介质

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2009054139A1 (ja) * 2007-10-24 2009-04-30 Panasonic Corporation 画像符号化方法、画像符号化装置、画像記録装置、及び集積回路
CN102143358A (zh) * 2010-01-29 2011-08-03 新奥特(北京)视频技术有限公司 一种具有集群管理功能的转码系统
CN103167318A (zh) * 2011-12-13 2013-06-19 中国电信股份有限公司 流媒体处理方法、装置和服务器、系统
CN105898318A (zh) * 2015-12-21 2016-08-24 乐视云计算有限公司 离线转码方法和系统

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103167138B (zh) * 2012-09-14 2015-10-07 深圳市金立通信设备有限公司 一种手机任意进制组合密码的实现系统及实现方法
CN104159127B (zh) * 2014-08-21 2019-02-22 北京奇艺世纪科技有限公司 一种视频转码方法、装置及系统
CN105868009A (zh) * 2016-03-23 2016-08-17 乐视控股(北京)有限公司 一种直播流软件转码任务管理方法和装置

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2009054139A1 (ja) * 2007-10-24 2009-04-30 Panasonic Corporation 画像符号化方法、画像符号化装置、画像記録装置、及び集積回路
CN102143358A (zh) * 2010-01-29 2011-08-03 新奥特(北京)视频技术有限公司 一种具有集群管理功能的转码系统
CN103167318A (zh) * 2011-12-13 2013-06-19 中国电信股份有限公司 流媒体处理方法、装置和服务器、系统
CN105898318A (zh) * 2015-12-21 2016-08-24 乐视云计算有限公司 离线转码方法和系统

Also Published As

Publication number Publication date
CN108521421A (zh) 2018-09-11
EP3579560A4 (en) 2019-12-18
EP3579560A1 (en) 2019-12-11
WO2019196158A1 (zh) 2019-10-17

Similar Documents

Publication Publication Date Title
CN108521421B (zh) 一种转码任务的处理方法、系统及任务管理服务器
EP2244426B1 (en) A method and system for evaluating users quality of experience and network device
CN111010614A (zh) 一种显示直播字幕的方法、装置、服务器及介质
JP6383424B2 (ja) クラウドストリーミングサービスのためのアプリケーションエラー検出方法、そのための装置及びシステム
US10863247B2 (en) Receiving device and data processing method
CN102412999B (zh) 一种基于抓包的远程故障定位方法、系统及设备
CN111586601B (zh) 网络辅助信息提供方法及相关设备
CN107800791B (zh) 一种进行调试的方法及设备
CN102257831B (zh) 一种视频质量评估的方法和网络节点
CN105099929B (zh) 网络控制方法、装置及相应设备
US10645140B2 (en) Method for processing transcoding task, system and task management server
CN103686448A (zh) 视频转码下载限速的方法和系统
EP2879337A1 (en) Communication system, method, and program
CN101989902A (zh) 一种数据重传方法及装置
CN110300278A (zh) 视频传输方法和设备
MX2014010243A (es) Metodo y servidor para enviar un flujo de datos a un cliente y metodo y cliente para recibir un flujo de datos de un servidor.
CN108243222A (zh) 服务器网络架构方法及装置
CN114679592A (zh) 边缘集群调度方法及装置
EP2524503B1 (en) Method and apparatus for transmitting video content compressed by codec
KR101484933B1 (ko) 컴퓨터 네트워크에서 데이터를 송신하기 위한 방법, 시스템, 서버, 디바이스, 컴퓨터 프로그램 및 컴퓨터 프로그램 제품
CN110830763A (zh) 一种监控视频巡检方法及装置
JP5945242B2 (ja) 品質監視装置、品質監視方法及びプログラム
KR101098826B1 (ko) 비디오 스트리밍 스케줄링 방법 및 장치
CN102413319B (zh) 一种移动侦测实现方法及设备
US10162733B2 (en) Debugging failure of a service validation test

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
CF01 Termination of patent right due to non-payment of annual fee
CF01 Termination of patent right due to non-payment of annual fee

Granted publication date: 20191112