CN108900865B - 服务器、转码任务的调度方法及执行方法 - Google Patents
服务器、转码任务的调度方法及执行方法 Download PDFInfo
- Publication number
- CN108900865B CN108900865B CN201810595191.9A CN201810595191A CN108900865B CN 108900865 B CN108900865 B CN 108900865B CN 201810595191 A CN201810595191 A CN 201810595191A CN 108900865 B CN108900865 B CN 108900865B
- Authority
- CN
- China
- Prior art keywords
- transcoding
- server
- target
- task
- value
- 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 79
- 230000036541 health Effects 0.000 claims abstract description 95
- 238000012545 processing Methods 0.000 claims abstract description 35
- 230000003862 health status Effects 0.000 claims description 46
- 238000012163 sequencing technique Methods 0.000 claims description 4
- 239000000126 substance Substances 0.000 claims 2
- 238000004590 computer program Methods 0.000 description 8
- 238000004364 calculation method Methods 0.000 description 5
- 230000006872 improvement Effects 0.000 description 5
- 230000005540 biological transmission Effects 0.000 description 4
- 230000006870 function Effects 0.000 description 4
- 230000002093 peripheral effect Effects 0.000 description 4
- 230000008569 process Effects 0.000 description 4
- 238000001514 detection method Methods 0.000 description 3
- 238000004891 communication Methods 0.000 description 2
- 238000013461 design Methods 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 239000002699 waste material Substances 0.000 description 2
- 230000003287 optical effect Effects 0.000 description 1
- 238000012360 testing method Methods 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/234—Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs
- H04N21/2343—Processing 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
- H04N21/234309—Processing 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 by transcoding between formats or standards, e.g. from MPEG-2 to MPEG-4 or from Quicktime to Realvideo
-
- 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/25—Management operations performed by the server for facilitating the content distribution or administrating data related to end-users or client devices, e.g. end-user or client device authentication, learning user preferences for recommending movies
- H04N21/262—Content or additional data distribution scheduling, e.g. sending additional data at off-peak times, updating software modules, calculating the carousel transmission frequency, delaying a video stream transmission, generating play-lists
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Databases & Information Systems (AREA)
- Information Transfer Between Computers (AREA)
Abstract
本发明实施例涉及数据处理技术领域,公开了一种服务器、转码任务的调度方法及执行方法。本发明实施例中,转码任务的调度方法包括:从至少一转码服务器接收状态信息;当从流媒体服务器接收到转码任务请求时,根据接收到的所述状态信息,判断是否存在目标转码服务器;目标转码服务器为所述健康状态结果满足预设条件的转码服务器;若存在,将目标转码服务器的地址信息发送至流媒体服务器,供流媒体服务器根据地址信息将转码任务发送至目标转码服务器,供目标转码服务器执行转码任务。本发明实施例还提供了一种转码任务的执行方法。本发明实施例能够避免健康状态不理想的转码服务器执行转码任务,从而提高了转码质量,提升了用户体验。
Description
技术领域
本发明实施例涉及数据处理技术领域,特别涉及一种服务器、转码任务的调度方法及执行方法。
背景技术
流媒体服务器(例如直播服务器)从客户端服务器接收到转码任务后,需要将转码任务调度给转码服务器,供转码服务器执行转码任务。现有的流媒体服务器通过DNS或HTTPDNS方式来获取转码服务器的IP地址,从而将转码任务发给该IP地址对应的转码服务器。
然而,发明人发现现有技术中至少存在如下问题:现有的转码任务的调度方法中,通过DNS或HTTPDNS方式来获取将要执行转码任务的转码服务器,调度方式比较随机和盲目,如果该转码服务器的当前健康状态不太理想(例如当前已过量承载和/或当前处理能力较低),可能严重影响转码质量,影响客户的体验。
发明内容
本发明实施方式的目的在于提供一种服务器、转码任务的调度方法及执行方法,能够避免健康状态不理想的转码服务器执行转码任务,从而提高了转码质量,提升了用户体验。
为解决上述技术问题,本发明的实施方式提供了一种转码任务的调度方法,包括:从至少一转码服务器接收状态信息;所述状态信息至少包括所述转码服务器的地址信息和健康状态结果;当从流媒体服务器接收到转码任务请求时,根据接收到的所述状态信息,判断是否存在目标转码服务器;所述目标转码服务器为所述健康状态结果满足预设条件的转码服务器;若存在,将所述目标转码服务器的地址信息发送至所述流媒体服务器,供所述流媒体服务器根据所述地址信息将转码任务发送至所述目标转码服务器,供所述目标转码服务器执行所述转码任务。
本发明的实施方式还提供了一种转码任务的执行方法,应用于转码服务器;所述转码任务的执行方法包括:获取状态信息;所述状态信息至少包括所述转码服务器的地址信息和健康状态结果;发送所述状态信息至调度服务器,供所述调度服务器在接收到转码任务请求时判断是否存在目标转码服务器,且在判定存在目标转码服务器后,将所述目标转码服务器的地址信息发送至所述流媒体服务器,供所述流媒体服务器根据所述地址信息将转码任务发送至对应的所述目标转码服务器,供所述目标转码服务器执行所述转码任务;其中,所述目标转码服务器为所述健康状态结果满足预设条件的转码服务器。
本发明的实施方式还提供了一种服务器,包括:至少一个处理器;以及,与所述至少一个处理器通信连接的存储器;其中,所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行上述的转码任务的调度方法。
本发明的实施方式还提供了一种服务器,包括:至少一个处理器;以及,与所述至少一个处理器通信连接的存储器;其中,所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行上述的转码任务的执行方法。
本发明的实施方式还提供了一种计算机可读存储介质,存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现上述的转码任务的调度方法。
本发明的实施方式还提供了一种计算机可读存储介质,存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现上述的转码任务的执行方法。
本发明实施方式相对于现有技术而言,从至少一转码服务器接收状态信息,状态信息包括转码服务器的地址信息与健康状态结果,当从流媒体服务器接收到转码任务请求时,根据接收到的状态信息,判断是否存在健康状态结果满足预设条件的目标转码服务器,若存在,将目标转码服务器的地址信息发送至流媒体服务器,供流媒体服务器根据地址信息将转码任务发送至目标转码服务器,供目标转码服务器执行转码任务;即本发明实施例根据转码服务器的健康状态结果来调度转码任务,由于执行转码任务的目标服务器的健康状态结果满足预设条件,替代了现有技术中盲目调度转码任务的方式,能够避免健康状态不理想的转码服务器执行转码任务,从而提高了转码质量,提升了用户体验。
另外,健康状态结果包括健康状态值,且所述健康状态值越小,表征所述健康状态结果越好;所述将所述目标转码服务器的地址信息发送至所述流媒体服务器,具体包括:若所述目标转码服务器的数量大于1,则根据所述目标转码服务器的健康状态值从小至大的顺序,对所述目标转码服务器进行排序;将排序的前N个所述目标转码服务器的地址信息发送至所述流媒体服务器;N为大于零的自然数。本发明实施例将健康状态较优的目标转码服务器发送至流媒体服务器,从而将转码任务调度至较优的目标转码服务器上,进一步提高了转码质量。
另外,转码任务请求包括所述转码服务器的请求数量;所述将所述目标转码服务器的地址信息发送至所述流媒体服务器,具体包括:判断所述目标转码服务器的数量是否大于所述请求数量;若所述目标转码服务器的数量大于所述请求数量,则将所述请求数量的所述目标转码服务器的地址信息发送至所述流媒体服务器。本实施例中,当目标转码服务器的数量大于或等于请求数量时,将请求数量的目标转码服务器的地址信息发送至流媒体服务器,满足了转码任务请求的同时,避免发送过多数量的目标转码服务器的地址信息,避免可能出现的资源闲置与浪费;
另外,获取所述状态信息,具体包括:从当前正在处理的转码任务中获取各个所述转码任务的目标分辨率;根据各个所述转码任务的目标分辨率,计算每种所述目标分辨率对应的转码任务的任务数;根据每种所述目标分辨率对应的转码任务的任务数和预设的处理每种所述目标分辨率的转码任务的标准完成数,计算所述转码服务器处理所有所述转码任务的能力消耗量;根据所述能力消耗量与预设的标准能力处理量生成所述健康状态结果。本实施例中,提供了状态信息的一种获取方式,该健康状态结果能够很好的反应出该转码服务器是否处于过量承载的状态,为调度服务器提供了便利的数据参考。
另外,健康状态结果包括所述转码服务器的健康状态值;所述根据所述能力消耗量与预设的标准能力处理量生成所述健康状态结果,具体包括:当所述能力消耗量大于或等于所述标准能力处理量时,将所述健康状态值设定为预设的特定值;当所述能力消耗量小于所述标准能力处理量时,根据所述转码服务器的每个内核的资源占用值计算所述健康状态值。本实施例中,提供了健康状态结果的一种表示方式,采用更为具体的健康状态值来反映转码服务器的健康程度,使得健康状态结果能够更好的反映转码服务器实际的健康状态,并且,提供了健康状态值的一种生成方式。
另外,根据所述转码服务器的每个内核的资源占用值计算所述健康状态值,具体包括:获取每个所述内核的资源占用值;将每个所述资源占用值按数值大小进行依次排序;计算从大至小依次排列的前M个所述资源占用值的平均值,并将所述平均值作为所述健康状态值;M为大于1的自然数。本实施例中,本实施例中,将从大至小依次排列的前M个资源占用值的平均值作为健康状态值,能够比较好的反应转码服务器的健康状态,提高了健康状态结果的准确度。
附图说明
一个或多个实施例通过与之对应的附图中的图片进行示例性说明,这些示例性说明并不构成对实施例的限定,附图中具有相同参考数字标号的元件表示为类似的元件,除非有特别申明,附图中的图不构成比例限制。
图1是根据第一实施方式的转码任务的调度方法的具体流程图;
图2是根据第二实施方式的转码任务的调度方法的具体流程图;
图3是根据第三实施方式的转码任务的调度方法的具体流程图;
图4是根据第四实施方式的转码任务的调度方法的具体流程图;
图5是根据第五实施方式的转码任务的调度方法的具体流程图;
图6是根据第六实施方式的转码任务的调度方法的具体流程图。
具体实施方式
为使本发明实施例的目的、技术方案和优点更加清楚,下面将结合附图对本发明的各实施方式进行详细的阐述。然而,本领域的普通技术人员可以理解,在本发明各实施方式中,为了使读者更好地理解本申请而提出了许多技术细节。但是,即使没有这些技术细节和基于以下各实施方式的种种变化和修改,也可以实现本申请所要求保护的技术方案。
本发明的第一实施方式涉及一种转码任务的调度方法,应用于调度服务器,如图1所示,转码任务的调度方法包括:
步骤101,从至少一转码服务器接收状态信息。
本实施方式中,至少一转码服务器与调度服务器预先通信连接。状态信息至少包括转码服务器的地址信息和健康状态结果。
步骤102,检测从流媒体服务器是否接收到转码任务请求;若是,执行步骤103,否则继续执行本步骤。
本实施方式中,流媒体服务器与调度服务器预先通信连接。调度服务器可以周期性的进行检测,检测周期例如为5分钟,本实施例对检测周期的数值不作任何限制。
步骤103,根据接收到的状态信息,判断是否存在目标转码服务器;若是,执行步骤104,否则返回执行步骤101。
本实施方式中,目标转码服务器为健康状态结果满足预设条件的转码服务器。
在一个例子中,健康状态结果包括表征健康程度的标识,通过判断是否存在与预设标识相匹配的标识,来判断是否存在目标服务器,然这里只是示例性说明,本实施例对目标服务器的判断方式不作任何限制。
步骤104,将目标转码服务器的地址信息发送至流媒体服务器。
本实施方式中,将目标服务器的地址信息发送给流媒体服务器,供流媒体服务器根据地址信息将转码任务发送至目标转码服务器,供目标转码服务器执行转码任务。
本发明的实施例相对于现有技术而言,从至少一转码服务器接收状态信息,状态信息包括转码服务器的地址信息与健康状态结果,当从流媒体服务器接收到转码任务请求时,根据接收到的状态信息,判断是否存在健康状态结果满足预设条件的目标转码服务器,若存在,将目标转码服务器的地址信息发送至流媒体服务器,供流媒体服务器根据地址信息将转码任务发送至目标转码服务器,供目标转码服务器执行转码任务;即本发明实施例根据转码服务器的健康状态结果来调度转码任务,由于执行转码任务的目标服务器的健康状态结果满足预设条件,替代了现有技术中盲目调度转码任务的方式,能够避免健康状态不理想的转码服务器执行转码任务,从而提高了转码质量,提升了用户体验。
下面对本实施方式的转码任务的调度方法的实现细节进行具体的说明,以下内容仅为方便理解提供的实现细节,并非实施本方案的必须。
在一个例子中,转码服务器的地址信息可以为IP地址信息,然实际中不限于此,本实施例对地址信息的具体类型不作任何限制。
在一个例子中,健康状态结果包括当前任务承载量,然实际中不限于此,本实施例对健康状态结果包括的信息不作任何限制。
在一个例子中,流媒体服务器例如为直播服务器,然实际中不限于此,本实施例对流媒体服务器的具体类型不作任何限制。
上面各种方法的步骤划分,只是为了描述清楚,实现时可以合并为一个步骤或者对某些步骤进行拆分,分解为多个步骤,只要包括相同的逻辑关系,都在本专利的保护范围内;对算法中或者流程中添加无关紧要的修改或者引入无关紧要的设计,但不改变其算法和流程的核心设计都在该专利的保护范围内。
本发明的第二实施方式涉及一种转码任务的调度方法。第二实施方式在第一实施方式的基础上进行改进,主要改进之处在于:在本发明第二实施方式中,提供了目标服务器的地址信息的一种具体发送方式。
本实施方式的转码任务的调度方法如图2所示,本实施方式的步骤201至步骤203与第一实施方式中的步骤101至103对应相同,本实施方式的步骤204包括以下子步骤:
子步骤2041,若目标转码服务器的数量大于1,则根据目标转码服务器的健康状态值从小至大的顺序,对目标转码服务器进行排序。
本实施方式中,健康状态结果包括健康状态值,且健康状态值越小,表征健康状态结果越好。
本实施方式中,健康状态值为预设的特定值时,表示转码服务器当前处理的所有转码任务的能力消耗量大于或等于转码服务器的标准能力处理量,也就是说特定值表示该转码服务器的健康状态不好,处于过量承载的状态。健康状态值不为特定值时,则健康状态值根据转码服务器的每个内核的资源占用值计算得到,例如可以将所有内核的资源占用值的平均值作为该健康状态值,然实际中不限于此,本实施例对该健康状态值的计算方式不作任何限制。
子步骤2042,将排序的前N个目标转码服务器的地址信息发送至流媒体服务器。
本实施方式中,N为大于零的自然数,N可以为3或4等,本实施例对N的具体数值不作任何限制。
本实施方式相对于第一实施方式而言,在目标服务器的数量大于1的情况下,根据目标服务器的健康状态值从小至大的顺序,对目标服务器进行排序,并且将排序的前N个目标服务器的地址信息发送至流媒体服务器,即本发明实施例将健康状态较优的目标转码服务器发送至流媒体服务器,从而将转码任务调度至较优的目标转码服务器上,进一步提高了转码质量。
本发明的第三实施方式涉及一种转码任务的调度方法。第三实施方式在第二实施方式的基础上进行改进,主要改进之处在于:在本发明第三实施方式中,提供了目标服务器的地址信息的另外一种具体发送方式。
本实施方式的转码任务的调度方法如图3所示,本实施方式的步骤301至步骤303与第一实施方式中的步骤101至103对应相同,本实施方式的步骤304包括以下子步骤:
子步骤3041,判断目标转码服务器的数量是否大于或等于请求数量;若是,执行步骤3042,否则执行步骤3043。
本实施方式中,转码任务请求包括转码服务器的请求数。在一个例子中,可以通过目标服务器的特定标识来确定目标转码服务器的数量,然后将目标服务器的数量与请求数量进行对比,从而判断出目标转码服务器的数量是否大于请求数量;然实际中不限于此,本实施例对该判断方式不作任何限制。
子步骤3042,将请求数量的目标转码服务器的地址信息发送至流媒体服务器。
子步骤3043,将所有目标转码服务器的地址信息发送至流媒体服务器。
本实施方式中,当目标服务器的数量小于请求数量时,将所有的目标服务器的地址信息发送至流媒体服务器,较佳的,还对该转码任务请求进行标记(并标记目标服务器的缺少数量,即所有目标服务器的数量与请求数量的差值),当存在新的目标服务器时,发送缺少数量的目标服务器的地址信息至流媒体服务器。
本发明的实施例相对于第一实施方式而言,当目标转码服务器的数量大于或等于请求数量时,将请求数量的目标转码服务器的地址信息发送至流媒体服务器,满足了转码任务请求的同时,避免发送过多数量的目标转码服务器的地址信息,避免可能出现的资源闲置与浪费;另外,在目标服务器的数量小于请求数量时,将所有目标服务器的地址信息发送至流媒体服务器,以便一定数量的转码任务尽可能被快速的执行。
本发明的第四实施方式涉及一种转码任务的执行方法,应用于转码服务器;如图4所示,转码任务的执行方法包括:
步骤401,获取状态信息。
本实施方式中,状态信息至少包括转码服务器的地址信息和健康状态结果。
在一个例子中,转码服务器的地址信息可以为IP地址信息,然实际中不限于此,本实施例对地址信息的具体类型不作任何限制。
在一个例子中,健康状态结果包括当前任务承载量,然实际中不限于此,本实施例对健康状态结果包括的信息不作任何限制。
步骤402,发送状态信息至调度服务器。
本实施方式中,转码服务器与调度服务器预先通信连接,调度服务器在接收到转码任务请求时判断是否存在目标转码服务器,且在判定存在目标转码服务器后,将目标转码服务器的地址信息发送至流媒体服务器,供流媒体服务器根据地址信息将转码任务发送至目标转码服务器,供目标转码服务器执行转码任务;其中,目标转码服务器为健康状态结果满足预设条件的转码服务器。
在一个例子中,健康状态结果包括表征健康程度的标识,预设条件为健康状态结果的标识与预设标识相匹配,然这里只是示例性说明,本实施例对预设条件不作任何限制不作任何限制。
本实施方式相对于现有技术而言,提供了一种应用于转码服务器上的转码任务的执行方法,即获取状态信息,状态信息至少包括转码服务器的地址信息和健康状态结果,发送状态信息至调度服务器,调度服务器在接收到转码任务请求时判断是否存在目标转码服务器,且在判定存在目标转码服务器后,将目标转码服务器的地址信息发送至流媒体服务器,供流媒体服务器根据地址信息将转码任务发送至目标转码服务器,供目标转码服务器执行转码任务;即本发明实施例使得调度服务器能够了解转码服务器的健康状态,从而使得调度服务器能够根据转码服务器的健康状态结果来调度转码任务,由于执行转码任务的目标服务器的健康状态结果满足预设条件,替代了现有技术中盲目调度转码任务的方式,能够避免健康状态不理想的转码服务器执行转码任务,从而提高了转码质量,提升了用户体验。
本发明的第五实施方式涉及一种转码任务的执行方法,第五实施方式在第四实施方式的基础上进行改进,主要改进之处在于:在本发明的第五实施方式中,提供了状态信息的一种获取方式。
本实施方式的转码任务的执行方法如图5所示,本实施方式的步骤502与第四实施方式中的步骤402对应相同,本实施方式的步骤501包括以下子步骤:
子步骤5011,从当前正在处理的转码任务中获取各个转码任务的目标分辨率。
本实施方式中,转码任务中包括目标分辨率。
子步骤5012,根据各个转码任务的目标分辨率,计算每种目标分辨率对应的转码任务的任务数。
在一个例子中,正在处理的转码任务有5个,目标分辨率分别是F1、F2、F1、F3及F1,则目标分辨率F1对应的转码任务的任务数为3,目标分辨率F2对应的转码任务的任务数为1,目标分辨率F3对应的转码任务的任务数为1,然这里只是示例性说明,实际中不限于此。
子步骤5013,根据每种目标分辨率对应的转码任务的任务数和预设的处理每种目标分辨率的转码任务的标准完成数,计算转码服务器处理所有转码任务的能力消耗量。
本实施方式中,预设的处理每种目标分辨率的转码任务的标准完成数,即处理不同目标分辨率的转码任务,标准完成数不同。
在一个例子中,转码服务器如果处理目标分辨率为F1的转码任务,能够处理10个,那么标准完成数即为10个;转码服务器如果处理目标分辨率为F2的转码任务,能够处理7个,那么标准完成数即为7个,然这里只是示例性说明,实际中不限于此。
在一个例子中,根据以下公式计算能力消耗量A:
其中,fn为第n种目标分辨率对应的转码任务的任务数,n大于或等于1,Xn为预设的处理第n种目标分辨率的转码任务的标准完成数;然这里只是示例性说明,本实施例对能力消耗量的计算方式不作任何限制。
子步骤5014,根据能力消耗量与预设的标准能力处理量生成健康状态结果。
本实施方式中,标准能力处理量,可预先对该转码服务器进行测试得到,它表征该转码服务器的标准处理能力。
在一个例子中,当能力消耗量大于或等于标准能力处理量时,则可生成不健康的健康状态结果(例如第一标识);当能力消耗量小于标准能力处理量时,则可生成健康的健康状态结果(例如第二标识);然这里只是示例性说明,实际中不限于此。
本发明的实施例相对于第四实施方式而言,根据每种目标分辨率对应的转码任务的任务数和预设的处理每种目标分辨率的转码任务的标准完成数,计算转码服务器处理所有转码任务的能力消耗量,根据能力消耗量与预设的标准能力处理量生成健康状态结果,即本发明实施例提供了状态信息的一种生成方式,该健康状态结果能够很好的反应出该转码服务器是否处于过量承载的状态,为调度服务器提供了便利的数据参考。
本发明的第六实施方式涉及一种转码任务的执行方法。第六实施方式在第五实施方式的基础上进行改进,主要改进之处在于:在本发明第六实施方式中,提供了健康状态结果的另外一种生成方式。
本实施方式的转码任务的调度方法如图6所示,本实施方式的步骤602与第五实施方式中的步骤502对应相同,本实施方式的步骤601中,子步骤6011至6013与第五实施方式的子步骤5011至5013对应相同,本实施方式的子步骤6014包括以下孙步骤:
孙步骤6014-1:判断能力消耗量是否大于或等于标准能力处理量;若是,执行孙步骤6014-2,否则执行孙步骤6014-3。
本实施方式中,健康状态结果包括转码服务器的健康状态值。
孙步骤6014-2,将健康状态值设定为预设的特定值。
本实施方式中,预设的特定值,表征该转码服务器的健康状态不好,特定值例如为100,然实际中不限于此,本实施例对特定值的具体数值不作任何限制。
孙步骤6014-3,根据转码服务器的每个内核的资源占用值计算健康状态值。
本实施方式中,转码服务器中的处理器包括多个内核,例如包括32个内核,然实际中不限于此,可根据实际情况进行计算。
在一个例子中,其中一个内核的资源被占用60%,则该资源占用值为60%,然这里只是示例性说明,实际中不限于此。
在一个例子中,可以计算所有内核的资源占用值的平均值,并将该平均值作为健康状态值,然实际中不限于此,本实施例对健康状态值的计算方式不作任何限制。
较佳的,在另一个例子中,首先,获取每个内核的资源占用值,其次,将每个资源占用值按数值大小进行依次排序,最后,计算从大至小依次排列的前M个资源占用值的平均值,并将平均值作为健康状态值;M为大于1的自然数。本实施例中,将从大至小依次排列的前M个资源占用值的平均值作为健康状态值,能够比较好的反应转码服务器的健康状态,提高了健康状态结果的准确度;然这里只是示例性说明,实际中不限于此。
在一个具体的例子中,M为8,即将从大至小依次排列的前8个资源占用值的平均值,作为健康状态值,然实际中不限于此,本实施例对M的具体数值不作任何限制,
本发明的实施方式相对于现有技术而言,提供了健康状态结果的一种表示方式,采用更为具体的健康状态值来反映转码服务器的健康程度,使得健康状态结果能够更好的反映转码服务器实际的健康状态,当能力消耗量大于或等于标准能力处理量时,则将健康状态值设定为预设的特定值,当能力消耗量小于标准能力处理量时,根据每个内核的资源占用值计算健康状态值。
本发明第七实施方式涉及一种服务器,包括:至少一个处理器;以及,与至少一个处理器通信连接的存储器;其中,存储器存储有可被至少一个处理器执行的指令,指令被至少一个处理器执行,以使至少一个处理器能够执行第一至第三实施方式中任一实施方式的转码任务的调度方法。
其中,存储器和处理器采用总线方式连接,总线可以包括任意数量的互联的总线和桥,总线将一个或多个处理器和存储器的各种电路连接在一起。总线还可以将诸如外围设备、稳压器和功率管理电路等之类的各种其他电路连接在一起,这些都是本领域所公知的,因此,本文不再对其进行进一步描述。总线接口在总线和收发机之间提供接口。收发机可以是一个元件,也可以是多个元件,比如多个接收器和发送器,提供用于在传输介质上与各种其他装置通信的单元。经处理器处理的数据通过天线在无线介质上进行传输,进一步,天线还接收数据并将数据传送给处理器。
处理器负责管理总线和通常的处理,还可以提供各种功能,包括定时,外围接口,电压调节、电源管理以及其他控制功能。而存储器可以被用于存储处理器在执行操作时所使用的数据。
本发明的实施方式相对于现有技术而言,从至少一转码服务器接收状态信息,状态信息包括转码服务器的地址信息与健康状态结果,当从流媒体服务器接收到转码任务请求时,根据接收到的状态信息,判断是否存在健康状态结果满足预设条件的目标转码服务器,若存在,将目标转码服务器的地址信息发送至流媒体服务器,供流媒体服务器根据地址信息将转码任务发送至目标转码服务器,供目标转码服务器执行转码任务;即本发明实施例根据转码服务器的健康状态结果来调度转码任务,由于执行转码任务的目标服务器的健康状态结果满足预设条件,替代了现有技术中盲目调度转码任务的方式,能够避免健康状态不理想的转码服务器执行转码任务,从而提高了转码质量,提升了用户体验。
本发明第八实施方式涉及一种服务器,包括:至少一个处理器;以及,与至少一个处理器通信连接的存储器;其中,存储器存储有可被至少一个处理器执行的指令,指令被至少一个处理器执行,以使至少一个处理器能够执行第四至第六实施方式中任一实施方式的转码任务的调度方法。
其中,存储器和处理器采用总线方式连接,总线可以包括任意数量的互联的总线和桥,总线将一个或多个处理器和存储器的各种电路连接在一起。总线还可以将诸如外围设备、稳压器和功率管理电路等之类的各种其他电路连接在一起,这些都是本领域所公知的,因此,本文不再对其进行进一步描述。总线接口在总线和收发机之间提供接口。收发机可以是一个元件,也可以是多个元件,比如多个接收器和发送器,提供用于在传输介质上与各种其他装置通信的单元。经处理器处理的数据通过天线在无线介质上进行传输,进一步,天线还接收数据并将数据传送给处理器。
处理器负责管理总线和通常的处理,还可以提供各种功能,包括定时,外围接口,电压调节、电源管理以及其他控制功能。而存储器可以被用于存储处理器在执行操作时所使用的数据。
本实施方式相对于现有技术而言,提供了一种应用于转码服务器上的转码任务的执行方法,即获取状态信息,状态信息至少包括转码服务器的地址信息和健康状态结果,发送状态信息至调度服务器,调度服务器在接收到转码任务请求时判断是否存在目标转码服务器,且在判定存在目标转码服务器后,将目标转码服务器的地址信息发送至流媒体服务器,供流媒体服务器根据地址信息将转码任务发送至目标转码服务器,供目标转码服务器执行转码任务;即本发明实施例使得调度服务器能够了解转码服务器的健康状态,从而使得调度服务器能够根据转码服务器的健康状态结果来调度转码任务,由于执行转码任务的目标服务器的健康状态结果满足预设条件,替代了现有技术中盲目调度转码任务的方式,能够避免健康状态不理想的转码服务器执行转码任务,从而提高了转码质量,提升了用户体验。
本发明第九实施方式涉及一种计算机可读存储介质,存储有计算机程序。计算机程序被处理器执行时实现第一至第三实施方式中任一实施方式的转码任务的调度方法。
本发明的实施方式相对于现有技术而言,从至少一转码服务器接收状态信息,状态信息包括转码服务器的地址信息与健康状态结果,当从流媒体服务器接收到转码任务请求时,根据接收到的状态信息,判断是否存在健康状态结果满足预设条件的目标转码服务器,若存在,将目标转码服务器的地址信息发送至流媒体服务器,供流媒体服务器根据地址信息将转码任务发送至目标转码服务器,供目标转码服务器执行转码任务;即本发明实施例根据转码服务器的健康状态结果来调度转码任务,由于执行转码任务的目标服务器的健康状态结果满足预设条件,替代了现有技术中盲目调度转码任务的方式,能够避免健康状态不理想的转码服务器执行转码任务,从而提高了转码质量,提升了用户体验。
本发明第十实施方式涉及一种计算机可读存储介质,存储有计算机程序。计算机程序被处理器执行时实现第四至第六实施方式中任一实施方式的转码任务的执行方法。
本实施方式相对于现有技术而言,提供了一种应用于转码服务器上的转码任务的执行方法,即获取状态信息,状态信息至少包括转码服务器的地址信息和健康状态结果,发送状态信息至调度服务器,调度服务器在接收到转码任务请求时判断是否存在目标转码服务器,且在判定存在目标转码服务器后,将目标转码服务器的地址信息发送至流媒体服务器,供流媒体服务器根据地址信息将转码任务发送至目标转码服务器,供目标转码服务器执行转码任务;即本发明实施例使得调度服务器能够了解转码服务器的健康状态,从而使得调度服务器能够根据转码服务器的健康状态结果来调度转码任务,由于执行转码任务的目标服务器的健康状态结果满足预设条件,替代了现有技术中盲目调度转码任务的方式,能够避免健康状态不理想的转码服务器执行转码任务,从而提高了转码质量,提升了用户体验。
即,本领域技术人员可以理解,实现上述实施例方法中的全部或部分步骤是可以通过程序来指令相关的硬件来完成,该程序存储在一个存储介质中,包括若干指令用以使得一个设备(可以是单片机,芯片等)或处理器(processor)执行本申请各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(ROM,Read-OnlyMemory)、随机存取存储器(RAM,Random Access Memory)、磁碟或者光盘等各种可以存储程序代码的介质。
本领域的普通技术人员可以理解,上述各实施方式是实现本发明的具体实施例,而在实际应用中,可以在形式上和细节上对其作各种改变,而不偏离本发明的精神和范围。
Claims (12)
1.一种转码任务的调度方法,其特征在于,包括:
从至少一转码服务器接收状态信息;所述状态信息至少包括所述转码服务器的地址信息和健康状态结果,所述健康状态结果根据所述转码服务器处理所有所述转码任务的能力消耗量与预设的标准能力处理量生成,其中,所述能力消耗量根据每种目标分辨率对应的转码任务的任务数和预设的处理每种所述目标分辨率的转码任务的标准完成数计算,所述目标分辨率对应的转码任务的任务数通过所述转码任务的目标分标率计算;
当从流媒体服务器接收到转码任务请求时,根据接收到的所述状态信息,判断是否存在目标转码服务器;所述目标转码服务器为所述健康状态结果满足预设条件的转码服务器;
若存在,将所述目标转码服务器的地址信息发送至所述流媒体服务器,供所述流媒体服务器根据所述地址信息将转码任务发送至所述目标转码服务器,供所述目标转码服务器执行所述转码任务。
2.根据权利要求1所述的转码任务的调度方法,其特征在于,所述健康状态结果包括健康状态值,且所述健康状态值越小,表征所述健康状态结果越好;所述将所述目标转码服务器的地址信息发送至所述流媒体服务器,具体包括:
若所述目标转码服务器的数量大于1,则根据所述目标转码服务器的健康状态值从小至大的顺序,对所述目标转码服务器进行排序;
将排序的前N个所述目标转码服务器的地址信息发送至所述流媒体服务器;N为大于零的自然数。
3.根据权利要求1所述的转码任务的调度方法,其特征在于,所述转码任务请求包括所述转码服务器的请求数量;所述将所述目标转码服务器的地址信息发送至所述流媒体服务器,具体包括:
判断所述目标转码服务器的数量是否大于或等于所述请求数量;
若所述目标转码服务器的数量大于所述请求数量,则将所述请求数量的所述目标转码服务器的地址信息发送至所述流媒体服务器。
4.根据权利要求2所述的转码任务的调度方法,其特征在于,所述健康状态值为预设的特定值时,表示所述转码服务器当前处理的所有所述转码任务的能力消耗量大于或等于所述转码服务器的标准能力处理量;
所述健康状态值不为所述特定值时,所述健康状态值根据所述转码服务器的每个内核的资源占用值计算得到。
5.根据权利要求1所述的转码任务的调度方法,其特征在于,所述地址信息为IP地址。
6.根据权利要求1所述的转码任务的调度方法,其特征在于,所述健康状态结果包括当前任务承载量。
7.一种转码任务的执行方法,其特征在于,应用于转码服务器;所述转码任务的执行方法包括:
获取状态信息;所述状态信息至少包括所述转码服务器的地址信息和健康状态结果;
所述获取所述状态信息,具体包括:
从当前正在处理的转码任务中获取各个所述转码任务的目标分辨率;
根据各个所述转码任务的目标分辨率,计算每种所述目标分辨率对应的转码任务的任务数;
根据每种所述目标分辨率对应的转码任务的任务数和预设的处理每种所述目标分辨率的转码任务的标准完成数,计算所述转码服务器处理所有所述转码任务的能力消耗量;
根据所述能力消耗量与预设的标准能力处理量生成所述健康状态结果;
发送所述状态信息至调度服务器,供所述调度服务器在接收到转码任务请求时判断是否存在目标转码服务器,且在判定存在目标转码服务器后,将所述目标转码服务器的地址信息发送至流媒体服务器,供所述流媒体服务器根据所述地址信息将转码任务发送至对应的所述目标转码服务器,供所述目标转码服务器执行所述转码任务;其中,所述目标转码服务器为所述健康状态结果满足预设条件的转码服务器。
8.根据权利要求7所述的转码任务的执行方法,其特征在于,所述健康状态结果包括所述转码服务器的健康状态值;所述根据所述能力消耗量与预设的标准能力处理量生成所述健康状态结果,具体包括:
当所述能力消耗量大于或等于所述标准能力处理量时,将所述健康状态值设定为预设的特定值;
当所述能力消耗量小于所述标准能力处理量时,根据所述转码服务器的每个内核的资源占用值计算所述健康状态值。
9.根据权利要求8所述的转码任务的执行方法,其特征在于,所述根据所述转码服务器的每个内核的资源占用值计算所述健康状态值,具体包括:
获取每个所述内核的资源占用值;
将每个所述资源占用值按数值大小进行依次排序;
计算从大至小依次排列的前M个所述资源占用值的平均值,并将所述平均值作为所述健康状态值;M为大于1的自然数。
11.一种服务器,其特征在于,包括:
至少一个处理器;以及,
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行如权利要求1至6中任一项所述的转码任务的调度方法。
12.一种服务器,其特征在于,包括:
至少一个处理器;以及,
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行如权利要求7至10中任一项所述的转码任务的执行方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810595191.9A CN108900865B (zh) | 2018-06-11 | 2018-06-11 | 服务器、转码任务的调度方法及执行方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810595191.9A CN108900865B (zh) | 2018-06-11 | 2018-06-11 | 服务器、转码任务的调度方法及执行方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN108900865A CN108900865A (zh) | 2018-11-27 |
CN108900865B true CN108900865B (zh) | 2021-06-15 |
Family
ID=64344600
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201810595191.9A Active CN108900865B (zh) | 2018-06-11 | 2018-06-11 | 服务器、转码任务的调度方法及执行方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN108900865B (zh) |
Families Citing this family (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113453043B (zh) * | 2020-03-27 | 2023-04-11 | 中国移动通信集团山东有限公司 | 一种视频调度优化方法、装置、计算机设备和存储介质 |
CN111479134A (zh) * | 2020-04-02 | 2020-07-31 | 亦非云互联网技术(上海)有限公司 | 分布式云转码方法、系统及服务器 |
Family Cites Families (14)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7155475B2 (en) * | 2002-02-15 | 2006-12-26 | Sony Corporation | System, method, and computer program product for media publishing request processing |
CN101909048B (zh) * | 2009-12-08 | 2013-03-06 | 新奥特(北京)视频技术有限公司 | 一种集中式转码处理方法和装置 |
CN101945278B (zh) * | 2010-09-15 | 2012-07-25 | 中国科学院深圳先进技术研究院 | 视频自适应转码方法和系统 |
CN102497370A (zh) * | 2011-12-12 | 2012-06-13 | 深圳市融创天下科技股份有限公司 | 一种在移动互联网发布及点播媒体节目的方法及系统 |
CN105095299A (zh) * | 2014-05-16 | 2015-11-25 | 北京奇虎科技有限公司 | 图片抓取方法和系统 |
CN105407413B (zh) * | 2014-09-11 | 2019-03-08 | 腾讯科技(深圳)有限公司 | 一种分布式视频转码方法及相关设备、系统 |
CN105657449B (zh) * | 2014-12-03 | 2018-12-28 | 中国移动通信集团公司 | 一种视频转码分配方法、装置及视频转码系统 |
TWI519967B (zh) * | 2015-03-25 | 2016-02-01 | 財團法人工業技術研究院 | 雲端運算資源動態分配系統及其方法 |
CN105828105B (zh) * | 2015-12-10 | 2019-02-22 | 广东亿迅科技有限公司 | 一种基于分布式环境的视频转码系统及视频转码方法 |
CN105871808A (zh) * | 2015-12-14 | 2016-08-17 | 乐视云计算有限公司 | 直播视频的转码方法及装置 |
CN105516347B (zh) * | 2015-12-31 | 2019-03-26 | 浙江大华系统工程有限公司 | 一种流媒体服务器的负载均衡调配的方法及装置 |
CN105872595A (zh) * | 2016-03-31 | 2016-08-17 | 乐视控股(北京)有限公司 | 转码任务分配方法及装置 |
CN106454402B (zh) * | 2016-08-31 | 2018-11-23 | 腾讯科技(深圳)有限公司 | 转码任务调度方法和装置 |
CN106851336B (zh) * | 2017-02-07 | 2020-04-14 | 上海网达软件股份有限公司 | 一种动态资源分配的音视频文件转码方法及系统 |
-
2018
- 2018-06-11 CN CN201810595191.9A patent/CN108900865B/zh active Active
Also Published As
Publication number | Publication date |
---|---|
CN108900865A (zh) | 2018-11-27 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7844705B2 (en) | Networked image visualization image quality enhancement method and system | |
CN107748696B (zh) | 一种任务调度的方法及终端设备 | |
CN111026553B (zh) | 离线混部作业的资源调度方法及服务器系统 | |
CN109815019B (zh) | 任务调度方法、装置、电子设备及可读存储介质 | |
CN105900064A (zh) | 调度数据流任务的方法和装置 | |
US9853906B2 (en) | Network prioritization based on node-level attributes | |
EP3255553A1 (en) | Transmission control method and device for direct memory access | |
CN111030945B (zh) | 容灾方法、容灾网关、存储介质、装置以及系统 | |
CN108900865B (zh) | 服务器、转码任务的调度方法及执行方法 | |
CN111105066A (zh) | 资源受限项目调度方法、装置、计算机设备、及存储介质 | |
US9501321B1 (en) | Weighted service requests throttling | |
CN112751785A (zh) | 待处理请求发送方法、装置、计算机设备及存储介质 | |
US11194619B2 (en) | Information processing system and non-transitory computer readable medium storing program for multitenant service | |
CN112416568A (zh) | 音视频转码任务的时长预估方法和时长预估装置 | |
CN111258729B (zh) | 基于Redis的任务分配方法、装置、计算机设备及存储介质 | |
CN111901425B (zh) | 基于Pareto算法的CDN调度方法、装置、计算机设备及存储介质 | |
CN114612037A (zh) | 一种仓库信息的管理方法和系统 | |
CN109901931B (zh) | 一种归约函数数量确定方法、装置及系统 | |
CN113590357A (zh) | 连接池的调整方法、装置、计算机设备及存储介质 | |
CN115373829A (zh) | Cpu资源的调度方法、装置及系统 | |
JP2006012065A (ja) | 資源負荷適正化管理システム | |
CN108881057B (zh) | 回源线路的选择方法和流量分发器 | |
CN110113434B (zh) | 作业自动调度均衡方法、装置、设备及存储介质 | |
CN113099488B (zh) | 解决网络拥塞的方法、装置、计算设备及计算机存储介质 | |
CN109583933B (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 |