CN103078847B - 一种多码率流文件的存储和读取方法及相关装置 - Google Patents

一种多码率流文件的存储和读取方法及相关装置 Download PDF

Info

Publication number
CN103078847B
CN103078847B CN201210567741.9A CN201210567741A CN103078847B CN 103078847 B CN103078847 B CN 103078847B CN 201210567741 A CN201210567741 A CN 201210567741A CN 103078847 B CN103078847 B CN 103078847B
Authority
CN
China
Prior art keywords
file
slicing files
stream
matchmaker
stream file
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
Application number
CN201210567741.9A
Other languages
English (en)
Other versions
CN103078847A (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.)
Shenzhen Coship Electronics Co Ltd
Original Assignee
Shenzhen Coship Electronics 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 Shenzhen Coship Electronics Co Ltd filed Critical Shenzhen Coship Electronics Co Ltd
Priority to CN201210567741.9A priority Critical patent/CN103078847B/zh
Publication of CN103078847A publication Critical patent/CN103078847A/zh
Application granted granted Critical
Publication of CN103078847B publication Critical patent/CN103078847B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Landscapes

  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Television Signal Processing For Recording (AREA)

Abstract

本发明公开了一种多码率流文件的存储和读取方法及相关装置。本发明通过对媒资文件包括的多码率媒体文件进行切片处理,并为每种码率的切片后形成的流文件添加索引文件,将多码率流文件的分片文件重新组装存储在一个媒资文件下,有利于将多码率流文件及小的分片文件组成的媒资资源兼容到现有的数字电视前端系统中,同时提高了分片文件的查询及读取效率。

Description

一种多码率流文件的存储和读取方法及相关装置
技术领域
本发明涉及三网融合技术领域,尤其一种多码率流文件的存储和读取方法及相关装置。
背景技术
三网融合,即电信网、数字电视网和互联网互联互通,资源共享。在三网融合的背景下,多码率自适应媒体服务协议越来越多地受到了运营商的欢迎。
现有技术中,三网融合时所用到的多码率自适应媒体文件往往都是切片后直接存放在磁盘中的,通常会以一种码率及文件名共同组成一个字符串来生成一个目录,在目录中存放该节目在特定码率下的文件分片,切片后的分片文件往往比较小,而媒体文件又比较大,因此,切片后会生成成千上万个分片文件,在读取时查询分片文件的效率非常低下。
而在2011年11月9日公布的申请公布号为CN 102238434A的技术提案中,在分片文件中插入用于索引的关键帧或标识,虽然有利于提高查询效率,但对于连续读取时缓存带来不便,使得磁盘读效率下降,同时也增加了业务软件的复杂度,且该方法只提供了单一码率文件的存储方法,而没有解决多码率文件的存储问题。
因此,针对在传统广电运营商的系统中单一媒资ID只对应一个视频文件的现有基础,以及多码率文件及小的分片文件组成的媒资资源很难兼容到现有系统中的问题,需要提供一种多码率流文件的存储和读取技术,以利用现有网络架构实现多码流文件的分发,以及提高分片文件的查询效率。
发明内容
本发明的目的在于提供一种多码率流文件的存储和读取方法及相关装置,用于将多码率流文件及小的分片文件组成的媒资资源兼容到现有的数字电视前端系统中,并提高分片文件的查询及读取效率。
本发明提供一种多码率流文件的存储方法,可包括:
获取媒体文件,生成待存储的媒资文件的索引头,所述索引头包括所述媒资文件的ID和每个所述媒体文件对应的码率;
对所述媒体文件进行切片处理,获得分片文件;
存储所述分片文件,以及存储索引文件,所述索引文件包括所述分片文件的ID和所述分片文件的存储位置,所述分片文件和索引文件组成流文件;
将所述流文件的索引文件的存储位置记录至所述媒资文件的索引头,所述媒资文件包括至少一个流文件。
优选地,所述对所述媒体文件进行切片处理,获得分片文件,包括:
对所述媒体文件按照设定的分片文件的播放时长,将所述媒体文件切片为至少一个分片文件。
优选地,所述存储所述分片文件,以及存储索引文件,包括:
针对任一个流文件,按照所述流文件中分片文件的播放顺序,依次存储所述流文件的分片文件;
在所述流文件的第一个分片文件之前或在所述流文件的最后一个分片文件之后,存储所述流文件的索引文件。
本发明提供一种多码率流文件的读取方法,可包括:
接收客户端的分片文件读取请求,所述请求包括请求的分片文件对应的媒资文件的ID、分片文件的码率和分片文件的ID;
根据所述媒资文件的ID,查找所述媒资文件的索引头,所述索引头包括所述媒资文件的ID、包含所述媒资文件的流文件对应的码率和每个所述流文件的索引文件的存储位置;
根据所述分片文件的码率,在所述索引头中获取与所述码率关联的所述流文件的索引文件的存储位置,所述索引文件包括所述分片文件的ID和所述分片文件的存储位置;
根据所述分片文件的ID,在所述索引文件中查找所述分片文件的ID对应的分片文件的存储位置;
从所述分片文件的存储位置读取所述分片文件,并将所述分片文件返回给所述客户端。
本发明提供一种多码率流文件的存储装置,可包括:
媒体文件获取模块,用于获取媒体文件;
索引头生成模块,用于生成待存储的媒资文件的索引头,所述索引头包括所述媒资文件的ID和每个所述媒体文件对应的码率;
切片模块,用于对所述媒体文件进行切片处理,获得分片文件;
存储模块,用于所述分片文件,以及存储索引文件,所述索引文件包括所述分片文件的ID和所述分片文件的存储位置,所述流文件包括所述分片文件和索引文件;
记录模块,用于将所述流文件的索引文件的存储位置记录至所述媒资文件的索引头,所述媒资文件包括至少一个流文件。
优选地,所述切片模块包括:
切片单元,用于对所述媒体文件按照设定的分片文件的播放时长,将所述媒体文件切片为至少一个分片文件。
优选地,所述存储模块包括:
分片文件存储单元,用于针对任一个流文件,按照所述流文件中分片文件的播放顺序,依次存储所述流文件的分片文件;
索引文件存储单元,用于在所述流文件的第一个分片文件之前或在所述流文件的最后一个分片文件之后,存储所述流文件的索引文件。
优选地,所述存储模块还包括:
流文件存储单元,用于如果所述媒资文件包含两个或两个以上的流文件,根据每个流文件的码率,将每个流文件依次存储。
本发明提供一种多码率流文件的读取装置,其特征在于,包括:
读取请求接收模块,用于接收客户端的分片文件读取请求,所述请求包括请求的分片文件对应的媒资文件的ID、分片文件的码率和分片文件的ID;
索引头查找模块,用于根据所述媒资文件的ID,查找所述媒资文件的索引头,所述索引头包括所述媒资文件的ID、包含所述媒资文件的流文件对应的码率和每个所述流文件的索引文件的存储位置;
索引文件获取模块,用于根据所述分片文件的码率,在所述索引头中获取与所述码率关联的所述流文件的索引文件的存储位置,所述索引文件包括所述分片文件的ID和所述分片文件的存储位置;
分片文件查找模块,用于根据所述分片文件的ID,在所述索引文件中查找所述分片文件的ID对应的分片文件的存储位置;
读取模块,用于从所述分片文件的存储位置读取所述分片文件;
返回模块,用于将所述读取单元读取的所述分片文件返回给所述客户端。
本发明提供一种中间件系统,其特征在于,包括前面所述的多码率流文件的存储装置和多码率流文件的读取装置。
本发明通过对媒资文件包括的多码率媒体文件进行切片处理,并为每种码率的切片后形成的流文件添加索引文件,将多码率流文件的分片文件重新组装存储在一个媒资文件下,有利于将多码率流文件及小的分片文件组成的媒资资源兼容到现有的数字电视前端系统中,同时提高了分片文件的查询及读取效率。
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1为本发明一种多码率流文件的存储方法的实施例的方法流程图;
图2为一个流文件的索引文件的结构示意图;
图3为一个媒资文件的索引头的结构示意图;
图4为对图1所示的本发明一种多码率流文件的存储方法的实施例的进一步细化的方法流程图;
图5为多个流文件存储在文件系统中的结构示意图;
图6为本发明一种多码率流文件的读取方法的实施例的方法流程图;
图7为本发明一种多码率流文件的存储装置的实施例的结构示意图;
图8为对图7所示的本发明一种多码率流文件的存储装置的实施例的进一步细化的结构示意图;
图9为本发明一种多码率流文件的读取装置的实施例的结构示意图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
本发明实施例提供一种多码率流文件的存储方法和读取方法及相关装置,通过对媒资文件包括的多码率媒体文件进行切片处理,并为每种码率的切片后形成的流文件添加索引文件,将多码率流文件的分片文件重新组装存储在一个媒资文件下,有利于将多码率流文件及小的分片文件组成的媒资资源兼容到现有的数字电视前端系统中,同时提高了分片文件的查询及读取效率。
图1为本发明一种多码率流文件的存储方法的实施例的方法流程图。数字电视前端系统的服务器包括一个中间件系统,由该中间件系统完成多码率流文件的存储,将多码率流文件存储于文件系统。如图1所示,该中间件系统执行多码率流文件的存储步骤如下:
步骤S101,获取媒体文件,生成待存储的媒资文件的索引头,该索引头包括媒资文件的ID和每个媒体文件对应的码率。
该中间件系统可以在线或离线获取媒体文件,该媒体文件可以是音频文件或视频文件。为适用三网融合应用市场,具有相同内容的媒体文件可以是多种不同的码率,例如:通过数字电视网络传输的影片A可以是码率为1600Kbps的媒体文件A1;通过互联网传输的影片A可以是码率为800Kbps的媒体文件A2;通过3G移动通信网络传输的影片A可以是码率为400Kbps的媒体文件A3。码率是数据传输时单位时间内传输的数据位数,不同的码率的流文件所呈现出画面质量不相同。中间件系统会对获取到的媒体文件进行解析,获取媒体文件的属性信息(包括媒体文件ID、文件大小、播放时长、码率等),并在文件系统中生成待存储的媒资文件的索引头,该索引头至少包括待存储的媒资文件的ID和每个媒体文件对应的码率。本发明实施例的媒资文件包含媒资文件的属性信息,如媒资文件的ID、媒资时长等,以及该媒资文件包括多少个流文件,以及每个流文件对应的码率。
步骤S102,对媒体文件进行切片处理,获得分片文件。
对媒体文件按照设定的参数进行切片处理,获得一个或多个分片文件。切片处理是按照设定的单个分片文件的播放时长,将该媒体文件切分为一个或多个分片文件的处理过程。为保证每种码率下的每个分片文件的完整性,该播放时长一定是整数个GOP(Group of Pictures,画面组)。获得的每个分片文件对应唯一的一个分片文件ID,如分片1、分片2等。
步骤S103,存储分片文件,以及存储索引文件,该索引文件包括分片文件的ID和分片文件的存储位置,该分片文件和索引文件组成流文件。
将分片文件保存至文件系统,同时存储索引文件,该索引文件至少包括分片文件的ID和分片文件的存储位置,分片文件的存储位置可以是绝对的存储空间地址或相对于索引文件的偏移位置等,该分片文件和索引文件一起组成流文件。如图2所示,为一个流文件的索引文件的结构示意图,该流文件被切分为分片1、分片2等多个分片文件,分片文件对应的存储位置分别为1001-1100、1101-2000等。在本发明实施例中,将单个媒体文件进行分片处理后获得的一个或多个分片文件,以及用于记录分片文件的ID的存储位置的索引文件一起组成单个流文件。因此,在步骤S101中所获得的媒体文件的码率即为流文件的码率。值得注意的是,虽然每个分片的播放时长是一样的,但由于其画面实际占用的存储空间不一样,所以每个分片的存储空间不一定是相等的。
步骤S104,将流文件的索引文件的存储位置记录至媒资文件的索引头,该媒资文件包括至少一个流文件。
完成步骤S103后,获得索引文件的存储位置,将其记录至步骤S101中的媒资文件的索引头。这样索引头就包括了媒资文件的ID、每个流文件对应的码率以及流文件的索引文件的存储位置。如图3所示,为一个媒资文件的索引头的结构示意图,该媒资文件包括多种码率的流文件,如码率1、码率2等,其关联的流文件的索引文件的存储位置分别为2001-2100、4001-4100等。
通过以上步骤,将该媒资文件的索引头、流文件的分片文件和索引文件依次保存至文件系统,重新组装为一个媒资文件,在文件系统中只体现为该媒资文件一个节点,这样就可以将多种码率的流文件组成的媒资资源兼容到现有的数字电视前端系统中。
根据本发明一种多码率流文件的存储方法的实施例,通过对媒资文件包括的多码率媒体文件进行切片处理,并为每种码率的切片后形成的流文件添加索引文件,将多码率流文件的分片文件重新组装存储在一个媒资文件下,有利于将多码率流文件及小的分片文件组成的媒资资源兼容到现有的数字电视前端系统中,同时提高了分片文件的查询及读取效率。
一个媒资文件可以包括一个或多个流文件,一个流文件包括一个或多个分片文件,下面通过具体实施例描述组装、存储分片文件和流文件的过程。
图4为对图1所示的本发明一种多码率流文件的存储方法的实施例的进一步细化的方法流程图。如图4所示,该方法包括以下步骤:
步骤S201,获取媒体文件,生成待存储的媒资文件的索引头,该索引头包括媒资文件的ID和每个媒体文件对应的码率。
步骤S201与前述实施例的步骤S101相同或类似,在此不再赘述。本实施例中系统同时获取两个以上媒体文件。
步骤S202,对媒体文件按照设定的分片文件的播放时长,将该媒体文件切片为至少一个分片文件。
依次对所述获得的两个以上媒体文件进行切片处理,其过程与前述实施例的步骤S102相同或类似,在此不再赘述。需要说明的是,为适应客户端对不同码率的分片文件的切换需求,每种码率下的媒体文件按照相同的播放时长进行切片处理,这样,当在网速不高时,播放码率1下的分片1,当网速变高时,可切换至码率2,以获得更高的画面质量,这时可以无缝地切换至码率2下的分片2,继续播放该节目。如图5所示的多个流文件的存储示意图,码率1对应的流文件1包括分片1、分片2至分片M和索引文件1,码率2对应的流文件2包括分片11、分片12至分片N和索引文件2,按照相同的播放时长进行切片处理,码率1对应的流文件包括的分片文件数量与其它码率对应的流文件相等。
步骤S203,针对任一个流文件,按照流文件中分片文件的播放顺序,依次存储该流文件的分片文件。
为了方便分片文件的读取,针对媒资文件的任一个流文件,一般按照该流文件中分片文件的播放顺序,依次存储该流文件的分片文件。如图5所示,如码率1对应的流文件1按照分片文件的播放顺序将分片1、分片2至分片M以及码率2对应的流文件2按照分片11、分片12至分片N等各流文件的分片文件依次保存到文件系统。
步骤S204,在该流文件的第一个分片文件之前或在该流文件的最后一个分片文件之后,存储该流文件的索引文件。
将设置好的索引文件存储在该流文件的第一个分片文件之前即该流文件的起始位置,也可以存储在该流文件的最后一个分片文件之后,即该流文件的结束位置,将索引文件存储在流文件的起始或结束位置,可以方便分片文件的连续读取。如图5所示,每个流文件的索引文件存储在该流文件的最后一个分片文件之后。
步骤S205,如果该媒资文件包含两个或两个以上的流文件,根据每个流文件的码率,将每个流文件依次存储。
媒资文件如果包含两个或两个以上的流文件,根据每个流文件的码率,将一个流文件存储完后,再存储另外一个流文件,依次存储完所有流文件。如图5所示,先存储码率1对应的流文件至文件系统,再存储码率2对应的流文件至文件系统,根据每个流文件的码率依次存储。
步骤S206,将流文件的索引文件的存储位置记录至媒资文件的索引头。
每存储完一个流文件,获取其索引文件的存储位置,将该流文件的索引文件的存储位置记录至媒资文件的索引头,如图5中码率1、2对应的流文件1、3的索引文件的存储位置分别为1101-1200和2101-2200。其记录方式与前述实施例的步骤S104相同或类似,在此不再赘述。
根据本发明一种多码率流文件的存储方法的实施例,通过对媒资文件包括的多码率媒体文件进行切片处理,并为每种码率的切片后形成的流文件添加索引文件,将多码率流文件的分片文件重新组装存储在一个媒资文件下,有利于将多码率流文件及小的分片文件组成的媒资资源兼容到现有的数字电视前端系统中,同时提高了分片文件的查询及读取效率。
图6为本发明一种多码率流文件的读取方法的实施例的方法流程图。客户端向数字电视前端系统的服务器请求某种码率下的分片文件,中间件系统接收客户端请求,能够通过媒资文件的索引头快速地读取根据前述实施例中的多码率流文件的存储位置。如图6所示,该多码率流文件的读取方法包括以下步骤:
步骤S301,接收客户端的分片文件读取请求,该请求包括请求的分片文件对应的媒资文件的ID、分片文件的码率和分片文件的ID。
数字电视前端系统的服务器接收客户端的分片文件读取请求,并将该请求交由服务器的中间件系统处理。该请求可以是由客户端通过Web服务器发送的视频点播请求,也可以是由客户端通过数字电视网络发送的视频点播请求。该请求包括请求的分片文件对应的媒资文件的ID、分片文件的码率和分片文件的ID,还可以包括鉴权、客户端ID、解码密钥等参数,对于通过Web服务器发送的请求,Web服务器先对客户端进行识别、鉴权等,然后根据请求的分片文件对应的媒资文件的ID、分片文件的码率和分片文件的ID向数字电视前端系统的中间件系统请求分片文件。
步骤S302,根据媒资文件的ID,查找媒资文件的索引头,该索引头包括媒资文件的ID、包含媒资文件的流文件对应的码率和每个流文件的索引文件的存储位置。
接收到客户端的请求后,中间件系统先根据媒资文件的ID,查找所有媒资文件的索引头,看是否存在对应该媒资文件的ID的索引头。该索引头包括媒资文件的ID,还包括流文件对应的码率和每个流文件的索引文件的存储位置。
步骤S303,根据分片文件的码率,在索引头中获取与该码率关联的流文件的索引文件的存储位置,该索引文件包括分片文件的ID和分片文件的存储位置。
索引头中流文件对应的码率与每个流文件的索引文件的存储位置关联,根据分片文件的码率,即该分片文件所属流文件的码率,可以获取与该码率关联的流文件的索引文件的存储位置。该索引文件是指包括分片文件的ID和分片文件的存储位置的流文件的索引文件。
步骤S304,根据分片文件的ID,在索引文件中查找该分片文件的ID对应的分片文件的存储位置。
在步骤S303中获取了索引文件的存储位置后,在文件系统中该索引文件的存储位置读取该索引文件,由于该索引文件包括分片文件的ID和其对应的存储位置,因此,根据分片文件的ID,在索引文件中查找该分片文件的ID对应的分片文件的存储位置。
步骤S305,从分片文件的存储位置读取分片文件,并将该分片文件返回给客户端。
从文件系统中分片文件的存储位置读取分片文件,并将该分片文件返回给Web服务器,Web服务器根据分片文件大小填写相关HTTP属性域,最后将分片文件发送到客户端,实现媒资文件的播放。
本领域技术人员容易理解的是,客户端的分片文件读取请求中的分片文件的ID可以是连续多个分片文件的ID,根据前述实施例中多码率流文件的存储方法,索引文件是存储在流文件的第一个分片文件之前或最后一个分片文件之后,因此,不影响分片文件的连续读取。
根据本发明提供的一种多码率流文件的读取方法的一个实施例,可以通过媒资文件标识读取到该媒资文件包括的多码率流文件的分片文件,通过索引能够方便地查找到请求的分片文件,极大地提高了分片文件的读取效率。
图7为本发明一种多码率流文件的存储装置的实施例的结构示意图。数字电视前端系统包括中间件系统,由该中间件系统的存储装置完成多码率流文件的存储,将多码率流文件存储于文件系统。如图7所示,该存储装置1000包括:
媒体文件获取模块101,用于获取媒体文件。
该中间件系统可以在线或离线获取媒体文件,该媒体文件可以是音频文件或视频文件。为适用三网融合应用市场,具有相同内容的媒体文件可以是多种不同的码率,例如:通过数字电视网络传输的影片A可以是码率为1600Kbps的媒体文件A1;通过互联网传输的影片A可以是码率为800Kbps的媒体文件A2;通过3G移动通信网络传输的影片A可以是码率为400Kbps的媒体文件A3。码率是数据传输时单位时间内传输的数据位数,不同的码率的流文件所呈现出画面质量不相同。
索引头生成模块102,用于生成待存储的媒资文件的索引头,该索引头包括媒资文件的ID和每个媒体文件对应的码率。
中间件系统会对获取到的媒体文件进行解析,获取媒体文件的属性信息(包括媒体文件ID、文件大小、播放时长、码率等),并在文件系统中生成待存储的媒资文件的索引头,该索引头至少包括待存储的媒资文件的ID和每个媒体文件对应的码率。本发明实施例的媒资文件包含媒资文件的属性信息,如媒资文件的ID、媒资时长等,以及该媒资文件包括多少个流文件,以及每个流文件对应的码率。
切片模块103,用于对媒体文件进行切片处理,获得分片文件。
对媒体文件按照设定的参数进行切片处理,获得一个或多个分片文件。切片处理是按照设定的单个分片文件的播放时长,将该媒体文件切分为一个或多个分片文件的处理过程。为保证每种码率下的每个分片文件的完整性,该播放时长一定是整数个GOP(Group of Pictures,画面组)。获得的每个分片文件对应唯一的一个分片文件ID,如分片1、分片2等。
存储模块104,用于存储分片文件,以及存储索引文件,该索引文件包括分片文件的ID和分片文件的存储位置,该分片文件和索引文件组成流文件。
将分片文件保存至文件系统,同时存储索引文件,该索引文件至少包括分片文件的ID和分片文件的存储位置,分片文件的存储位置可以是绝对的存储空间地址或相对于索引文件的偏移位置等,该分片文件和索引文件一起组成流文件。如图2所示,为一个流文件的索引文件的结构示意图,该流文件被切分为分片1、分片2等多个分片文件,分片文件对应的存储位置分别为1001-1100、1101-2000等。在本发明实施例中,将单个媒体文件进行分片处理后获得的一个或多个分片文件,以及用于记录分片文件的ID的存储位置的索引文件一起组成单个流文件。因此,在步骤S101中所获得的媒体文件的码率即为流文件的码率。值得注意的是,虽然每个分片的播放时长是一样的,但由于其画面实际占用的存储空间不一样,所以每个分片的存储空间不一定是相等的。
记录模块105,用于将流文件的索引文件的存储位置记录至媒资文件的索引头,该媒资文件包括至少一个流文件。
获得索引文件的存储位置,将其记录至媒资文件的索引头。这样索引头就包括了媒资文件的ID、每个流文件对应的码率以及流文件的索引文件的存储位置。如图3所示,为一个媒资文件的索引头的结构示意图,该媒资文件包括多种码率的流文件,如码率1、码率2等,其关联的流文件的索引文件的存储位置分别为2001-2100、4001-4100等。
这样,就将该媒资文件的索引头、流文件的分片文件和索引文件依次保存至文件系统,重新组装为一个媒资文件,在文件系统中只体现为该媒资文件一个节点,这样就可以将多种码率的流文件组成的媒资资源兼容到现有的数字电视前端系统中。
根据本发明一种多码率流文件的存储装置的实施例,通过对媒资文件包括的多码率媒体文件进行切片处理,并为每种码率的切片后形成的流文件添加索引文件,将多码率流文件的分片文件重新组装存储在一个媒资文件下,有利于将多码率流文件及小的分片文件组成的媒资资源兼容到现有的数字电视前端系统中,同时提高了分片文件的查询及读取效率。
一个媒资文件可以包括一个或多个流文件,一个流文件又包括一个或多个分片文件,下面通过具体实施例描述组装、存储分片文件和流文件的过程。
图8为对图7所示的本发明一种多码率流文件的存储装置的实施例的进一步细化的结构示意图。如图8所示,该存储装置2000包括:
媒体文件获取模块101,用于获取媒体文件。
索引头生成模块102,用于生成待存储的媒资文件的索引头,该索引头包括媒资文件的ID和每个媒体文件对应的码率。
在本实施例中,媒体文件获取模块101和索引头生成模块102分别与前述实施例的媒体文件获取模块101和索引头生成模块102的功能相同或类似,在此不再赘述。值得说明的是,本实施例中系统同时获取两个以上媒体文件,媒体文件获取模块101可以分别或一次全部获取媒体文件,索引头生成模块102生成索引头,该索引头包括媒资文件的ID和每个媒体文件对应的码率。
切片模块103,用于对媒体文件进行切片处理,获得分片文件。
在本实施例中,切片模块103包括切片单元106。
切片单元106,用于对媒体文件按照设定的分片文件的播放时长,将该媒体文件切片为至少一个分片文件。
切片单元106依次对所述获得的两个以上媒体文件进行切片处理。切片处理是按照设定的分片文件的播放时长,将该媒体文件切分为一个或多个分片文件的处理过程。为保证每种码率下的每个分片文件的完整性,该播放时长一定是整数个GOP(Group of Pictures,画面组)。获得的每个分片文件对应唯一的一个ID,如分片1、分片2等。
需要说明的是,为适应客户端对不同码率的分片文件的切换需求,每种码率下的媒体文件按照相同的播放时长进行切片处理,这样,当在网速不高时,播放码率1下的分片1,当网速变高时,可切换至码率2,以获得更高的画面质量,这时可以无缝地切换至码率2下的分片2,继续播放该节目。如图5所示的多个流文件的存储示意图,码率1对应的流文件1包括分片1、分片2至分片M和索引文件1,码率2对应的流文件2包括分片11、分片12至分片N和索引文件2,按照相同的播放时长进行切片处理,码率1对应的流文件包括的分片文件数量与其它码率对应的流文件相等。
存储模块104,用于存储分片文件,以及存储索引文件,该索引文件包括分片文件的ID和分片文件的存储位置,该分片文件和索引文件组成流文件。
在本实施例中,存储模块104包括分片文件存储单元107、索引文件存储单元108和流文件存储单元109。
分片文件存储单元107,用于针对任一个流文件,按照流文件中分片文件的播放顺序,依次存储该流文件的分片文件。
为了方便分片文件的读取,针对媒资文件的任一个流文件,一般按照该流文件中分片文件的播放顺序,依次存储该流文件的分片文件。如图5所示,如码率1对应的流文件1按照分片文件的播放顺序将分片1、分片2至分片M以及码率2对应的流文件2按照分片11、分片12至分片N等各流文件的分片文件依次保存到文件系统。
索引文件存储单元108,用于在该流文件的第一个分片文件之前或在该流文件的最后一个分片文件之后,存储该流文件的索引文件。
将设置好的索引文件存储在该流文件的第一个分片文件之前即该流文件的起始位置,也可以存储在该流文件的最后一个分片文件之后,即该流文件的结束位置,将索引文件存储在流文件的起始或结束位置,可以方便分片文件的连续读取。如图5所示,每个流文件的索引文件存储在该流文件的最后一个分片文件之后。
流文件存储单元109,用于如果该媒资文件包含两个或两个以上的流文件,根据每个流文件的码率,将每个流文件依次存储。
媒资文件如果包含两个或两个以上的流文件,根据每个流文件的码率,将一个流文件存储完后,再存储另外一个流文件,依次存储完所有流文件。如图5所示,先存储码率1对应的流文件至文件系统,再存储码率2对应的流文件至文件系统,根据每个流文件的码率依次存储。
记录单元105,用于将流文件的索引文件的存储位置记录至媒资文件的索引头。
每存储完一个流文件,获取其索引文件的存储位置,将该流文件的索引文件的存储位置记录至媒资文件的索引头,如图5中码率1、2对应的流文件1、3的索引文件的存储位置分别为1101-1200和2101-2200。其记录方式与前述实施例的步骤S104相同或类似,在此不再赘述。
根据本发明一种多码率流文件的存储装置的实施例,通过对媒资文件包括的多码率媒体文件进行切片处理,并为每种码率的切片后形成的流文件添加索引文件,将多码率流文件的分片文件重新组装存储在一个媒资文件下,有利于将多码率流文件及小的分片文件组成的媒资资源兼容到现有的数字电视前端系统中,同时提高了分片文件的查询及读取效率。
图9为本发明一种多码率流文件的读取装置的实施例的结构示意图。客户端向数字电视前端系统的服务器请求某种码率下的分片文件,中间件系统的读取装置接收客户端请求,能够通过媒资文件的索引头快速地读取根据前述实施例中的多码率流文件的存储位置。如图9所示,该多码率流文件的读取装置3000包括:
读取请求接收模块201,用于接收客户端的分片文件读取请求,该请求包括请求的分片文件对应的媒资文件的ID、分片文件的码率和分片文件的ID。
数字电视前端系统的服务器接收客户端的分片文件读取请求,并将该请求交由服务器的中间件系统的读取装置处理。该请求可以是由客户端通过Web服务器发送的视频点播请求,也可以是由客户端通过数字电视网络发送的视频点播请求。该请求包括请求的分片文件对应的媒资文件的ID、分片文件的码率和分片文件的ID,还可以包括鉴权、客户端ID、解码密钥等参数,对于通过Web服务器发送的请求,Web服务器先对客户端进行识别、鉴权等,然后根据请求的分片文件对应的媒资文件的ID、分片文件的码率和分片文件的ID向读取请求接收模块201请求分片文件。
索引头查找模块202,用于根据媒资文件的ID,查找媒资文件的索引头,该索引头包括媒资文件的ID、包含媒资文件的流文件对应的码率和每个流文件的索引文件的存储位置。
接收到客户端的请求后,索引头查找模块202先根据媒资文件的ID,查找所有媒资文件的索引头,看是否存在对应该媒资文件的ID的索引头。该索引头包括媒资文件的ID,还包括流文件对应的码率和每个流文件的索引文件的存储位置。
索引文件模块203,用于根据分片文件的码率,在索引头中获取与该码率关联的流文件的索引文件的存储位置,该索引文件包括分片文件的ID和分片文件的存储位置。
索引头中流文件对应的码率与每个流文件的索引文件的存储位置关联,根据分片文件的码率,即该分片文件所属流文件的码率,可以获取与该码率关联的流文件的索引文件的存储位置。该索引文件是指包括分片文件的ID和分片文件的存储位置的流文件的索引文件。
分片文件查找模块204,用于根据分片文件的ID,在索引文件中查找该分片文件的ID对应的分片文件的存储位置。
索引文件模块203获取了索引文件的存储位置后,分片文件查找模块204在文件系统中该索引文件的存储位置读取该索引文件,由于该索引文件包括分片文件的ID和其对应的存储位置,因此,根据分片文件的ID,在索引文件中查找该分片文件的ID对应的分片文件的存储位置。
读取模块205,用于从分片文件的存储位置读取分片文件。
返回模块206,用于将读取单元读取的分片文件返回给客户端。
读取模块205从文件系统中分片文件的存储位置读取分片文件,并将该分片文件返回给Web服务器,Web服务器根据分片文件大小填写相关HTTP属性域,最后将分片文件发送到客户端,实现媒资文件的播放。
本领域技术人员容易理解的是,客户端的分片文件读取请求中的分片文件的ID可以是连续多个分片文件的ID,根据前述实施例中多码率流文件的存储方法,索引文件是存储在流文件的第一个分片文件之前或最后一个分片文件之后,因此,不影响分片文件的连续读取。
根据本发明提供的一种多码率流文件的读取装置的实施例,可以通过媒资文件标识读取到该媒资文件包括的多码率流文件的分片文件,通过索引能够方便地查找到请求的分片文件,极大地提高了分片文件的读取效率。
本发明还提供一种中间件系统,其位于服务器中的文件系统之上,客户端向中间件系统提交分片文件的请求,然后由中间件系统从文件系统获取分片文件返回给客户端。该中间件系统包括前述实施例的多码率流文件的存储装置和多码率流文件的读取装置。
所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的设备和模块的具体工作过程,可以参考前述方法实施例中的对应过程描述,在此不再赘述。
在本申请所提供的几个实施例中,应该理解到,所揭露的设备和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述模块的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个模块或组件可以结合或者可以集成到另一个设备中,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些通信接口,装置或模块的间接耦合或通信连接,可以是电性,机械或其它的形式。
所述作为分离部件说明的模块可以是或者也可以不是物理上分开的,作为模块显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部,模块来实现本实施例方案的目的。
另外,在本发明各个实施例中的各功能模块可以集成在一个处理模块中,也可以是各个模块单独物理存在,也可以两个或两个以上模块集成在一个模块中。
最后应说明的是:以上各实施例仅用以说明本发明的技术方案,而非对其限制;尽管参照前述各实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分或者全部技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的范围。

Claims (10)

1.一种多码率流文件的存储方法,应用于中间件系统,其特征在于,包括:
获取媒体文件,生成待存储的媒资文件的索引头,所述索引头包括所述媒资文件的ID和每个所述媒体文件对应的码率;
对所述媒体文件进行切片处理,获得分片文件;
存储所述分片文件至文件系统,以及存储索引文件至所述文件系统,所述索引文件包括所述分片文件的ID和所述分片文件的存储位置,所述分片文件和索引文件组成流文件;
将所述流文件的索引文件的存储位置记录至所述媒资文件的索引头,所述媒资文件包括至少一个流文件。
2.如权利要求1所述的方法,其特征在于,所述对所述媒体文件进行切片处理,获得分片文件,包括:
对所述媒体文件按照设定的分片文件的播放时长,将所述媒体文件切片为至少一个分片文件。
3.如权利要求2所述的方法,其特征在于,所述存储所述分片文件,以及存储索引文件,包括:
针对任一个流文件,按照所述流文件中分片文件的播放顺序,依次存储所述流文件的分片文件;
在所述流文件的第一个分片文件之前或在所述流文件的最后一个分片文件之后,存储所述流文件的索引文件。
4.一种多码率流文件的读取方法,应用于中间件系统,其特征在于,包括:
接收客户端的分片文件读取请求,所述请求包括请求的分片文件对应的媒资文件的ID、分片文件的码率和分片文件的ID;
根据所述媒资文件的ID,查找所述媒资文件的索引头,所述索引头包括所述媒资文件的ID、包含所述媒资文件的流文件对应的码率和每个所述流文件的索引文件的存储位置;
根据所述分片文件的码率,在所述索引头中获取与所述码率关联的所述流文件的索引文件在文件系统中的存储位置,所述索引文件包括所述分片文件的ID和所述分片文件在所述文件系统中的存储位置;
根据所述分片文件的ID,在所述索引文件中查找所述分片文件的ID对应的分片文件的存储位置;
从所述分片文件的存储位置读取所述分片文件,并将所述分片文件返回给所述客户端。
5.一种多码率流文件的存储装置,其特征在于,包括:
媒体文件获取模块,用于获取媒体文件;
索引头生成模块,用于生成待存储的媒资文件的索引头,所述索引头包括所述媒资文件的ID和每个所述媒体文件对应的码率;
切片模块,用于对所述媒体文件进行切片处理,获得分片文件;
存储模块,用于存储所述分片文件至文件系统,以及存储索引文件至所述文件系统,所述索引文件包括所述分片文件的ID和所述分片文件的存储位置,所述流文件包括所述分片文件和索引文件;
记录模块,用于将所述流文件的索引文件的存储位置记录至所述媒资文件的索引头,所述媒资文件包括至少一个流文件。
6.如权利要求5所述的装置,其特征在于,所述切片模块包括:
切片单元,用于对所述媒体文件按照设定的分片文件的播放时长,将所述媒体文件切片为至少一个分片文件。
7.如权利要求6所述的装置,其特征在于,所述存储模块包括:
分片文件存储单元,用于针对任一个流文件,按照所述流文件中分片文件的播放顺序,依次存储所述流文件的分片文件;
索引文件存储单元,用于在所述流文件的第一个分片文件之前或在所述流文件的最后一个分片文件之后,存储所述流文件的索引文件。
8.如权利要求7所述的装置,其特征在于,所述存储模块还包括:
流文件存储单元,用于如果所述媒资文件包含两个或两个以上的流文件,根据每个流文件的码率,将每个流文件依次存储。
9.一种多码率流文件的读取装置,其特征在于,包括:
读取请求接收模块,用于接收客户端的分片文件读取请求,所述请求包括请求的分片文件对应的媒资文件的ID、分片文件的码率和分片文件的ID;
索引头查找模块,用于根据所述媒资文件的ID,查找所述媒资文件的索引头,所述索引头包括所述媒资文件的ID、包含所述媒资文件的流文件对应的码率和每个所述流文件的索引文件的存储位置;
索引文件获取模块,用于根据所述分片文件的码率,在所述索引头中获取与所述码率关联的所述流文件的索引文件在文件系统中的存储位置,所述索引文件包括所述分片文件的ID和所述分片文件在所述文件系统中的存储位置;
分片文件查找模块,用于根据所述分片文件的ID,在所述索引文件中查找所述分片文件的ID对应的分片文件的存储位置;
读取模块,用于从所述分片文件的存储位置读取所述分片文件;
返回模块,用于将所述读取模块读取的所述分片文件返回给所述客户端。
10.一种中间件系统,其特征在于,包括权利要求5-8任意一项所述的多码率流文件的存储装置和权利要求9所述的多码率流文件的读取装置。
CN201210567741.9A 2012-12-24 2012-12-24 一种多码率流文件的存储和读取方法及相关装置 Active CN103078847B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201210567741.9A CN103078847B (zh) 2012-12-24 2012-12-24 一种多码率流文件的存储和读取方法及相关装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201210567741.9A CN103078847B (zh) 2012-12-24 2012-12-24 一种多码率流文件的存储和读取方法及相关装置

Publications (2)

Publication Number Publication Date
CN103078847A CN103078847A (zh) 2013-05-01
CN103078847B true CN103078847B (zh) 2017-02-15

Family

ID=48155251

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201210567741.9A Active CN103078847B (zh) 2012-12-24 2012-12-24 一种多码率流文件的存储和读取方法及相关装置

Country Status (1)

Country Link
CN (1) CN103078847B (zh)

Families Citing this family (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104243430A (zh) * 2013-06-20 2014-12-24 腾讯科技(深圳)有限公司 一种流媒体播放方法及装置
CN103905695B (zh) * 2014-04-10 2018-01-09 中央电视台 一种素材处理方法及装置
CN104270646A (zh) * 2014-09-22 2015-01-07 何震宇 一种基于移动流媒体的自适应传输方法和系统
CN104506493B (zh) * 2014-12-04 2018-02-27 武汉市烽视威科技有限公司 一种实现hls内容回源和缓存的方法
CN104519372B (zh) * 2014-12-19 2017-11-21 深圳市九洲电器有限公司 一种流媒体播放的切换方法和系统
CN106686411A (zh) * 2015-11-10 2017-05-17 中兴通讯股份有限公司 流媒体频道录制方法、装置及回看方法、装置及服务器
CN106791959A (zh) * 2015-11-19 2017-05-31 中国电信股份有限公司 一种通过组播传输hls流媒体的方法、系统和终端
CN106791925B (zh) * 2017-02-09 2020-12-15 阿里巴巴(中国)有限公司 视频生成方法及装置
CN106791924A (zh) * 2017-02-09 2017-05-31 合网络技术(北京)有限公司 视频生成方法及装置
CN108712454B (zh) * 2018-02-13 2020-11-17 创新先进技术有限公司 一种文件处理方法、装置及设备
WO2020034082A1 (zh) * 2018-08-14 2020-02-20 海能达通信股份有限公司 基于切片的rtp流传输方法、装置、终端及服务器
CN110830821A (zh) * 2018-08-14 2020-02-21 海能达通信股份有限公司 基于切片的rtp流传输方法、装置、终端及服务器
CN109981751B (zh) * 2019-03-06 2022-06-17 珠海金山网络游戏科技有限公司 一种文件传输方法及系统、计算机设备及存储介质
CN116137670A (zh) * 2021-11-16 2023-05-19 中兴通讯股份有限公司 媒体文件聚合方法、播放方法、cdn系统、终端、存储介质

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101227602A (zh) * 2007-01-18 2008-07-23 中兴通讯股份有限公司 文件存储方法和文件播放方法
CN101917388A (zh) * 2009-12-17 2010-12-15 新奥特(北京)视频技术有限公司 一种流媒体数据存储方法及装置
CN102238434A (zh) * 2011-07-22 2011-11-09 中兴通讯股份有限公司 一种iptv流媒体文件虚拟分段和使用的方法及系统
CN102413358A (zh) * 2011-08-12 2012-04-11 青岛海信传媒网络技术有限公司 流媒体文件存储和播放的方法、装置及系统

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101141627A (zh) * 2007-10-23 2008-03-12 深圳市迅雷网络技术有限公司 一种流媒体文件的存储系统及方法

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101227602A (zh) * 2007-01-18 2008-07-23 中兴通讯股份有限公司 文件存储方法和文件播放方法
CN101917388A (zh) * 2009-12-17 2010-12-15 新奥特(北京)视频技术有限公司 一种流媒体数据存储方法及装置
CN102238434A (zh) * 2011-07-22 2011-11-09 中兴通讯股份有限公司 一种iptv流媒体文件虚拟分段和使用的方法及系统
CN102413358A (zh) * 2011-08-12 2012-04-11 青岛海信传媒网络技术有限公司 流媒体文件存储和播放的方法、装置及系统

Non-Patent Citations (3)

* Cited by examiner, † Cited by third party
Title
3GPP.Transparent end-to-end Packet-switched Streaming Service (PSS) Progressive Download and Dynamic Adaptive Streaming over HTTP (3GP-DASH).《3GPP TS 26.247 V10.2.0》.2012, *
Dynamic Adaptive HTTP Streaming of Live Content;Thorsten Lohmar等;《World of Wireless, Mobile and Multimedia Networks (WoWMoM), 2011 IEEE International Symposium on a》;20110623;正文第1-8页 *
The MPEG-DASH Standard for Multimedia Streaming Over the Internet;Sodagar Iraj;《MultiMedia,IEEE》;20111114;第18卷(第4期);正文第62-66页、图2-3 *

Also Published As

Publication number Publication date
CN103078847A (zh) 2013-05-01

Similar Documents

Publication Publication Date Title
CN103078847B (zh) 一种多码率流文件的存储和读取方法及相关装置
US8667158B2 (en) Video splitting and distributed placement scheme for clustered video servers
CN109348171B (zh) 一种视联网监控视频获取方法及装置
CN104506493B (zh) 一种实现hls内容回源和缓存的方法
CN110121059B (zh) 监控视频处理方法、装置及存储介质
CN101677325B (zh) 发布媒体描述信息和获取媒体的方法、装置、系统
WO2013159703A1 (en) Offline download method, multimedia file download method and system thereof
CN109889780B (zh) 数据同步方法和装置
CN105659623B (zh) 发送装置、发送方法、接收装置以及接收方法
CN109634988B (zh) 一种监控轮询方法和装置
CN109672857B (zh) 监控资源的信息处理方法和装置
CN102255942A (zh) 一种多媒体量子流及云处理技术与实现方法
CN102685561A (zh) 节目轮播的方法、系统、终端设备和节目点播装置
CN110072126A (zh) 数据请求方法、协转服务器及计算机可读存储介质
CN110475131B (zh) 一种终端连接方法、服务器和终端
CN110572698B (zh) 一种统计巡检和监控播放记录的方法、装置、设备、介质
CN111125426A (zh) 一种数据存储和查询的方法及装置
CN110502548A (zh) 一种搜索结果推荐方法、装置及计算机可读存储介质
CN107959704A (zh) 一种数据处理方法及家庭网关
CN101656947A (zh) 跨异构网络业务共享建立方法、设备及系统
CN111212255A (zh) 监控资源获取方法、装置及计算机可读存储介质
CN106210779B (zh) 优化网络视频直播数据分层传输的方法及系统
KR102193806B1 (ko) Ar 콘텐츠의 실시간 분산 송출시스템
CN111193619B (zh) 一种日志文件的采集方法及装置
CN110619074A (zh) 一种基于视联网的搜索方法和视联网管理平台

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
ASS Succession or assignment of patent right

Owner name: SHENZHEN TONGZHOU ELECTRONIC CO., LTD.

Free format text: FORMER OWNER: SHENZHEN LONGSHI MEDIA CO., LTD.

Effective date: 20140509

C41 Transfer of patent application or patent right or utility model
TA01 Transfer of patent application right

Effective date of registration: 20140509

Address after: 518057 Nanshan District hi tech park, Guangdong, North District Rainbow science and Technology Building

Applicant after: Shenzhen Tongzhou Electronic Co., Ltd.

Address before: 518057 District, Guangdong, Nanshan District hi tech Zone, the North Zone of the Fifth Industrial Zone, rainbow science and technology building, A2-3 District,

Applicant before: Shenzhen Longguan Media Co., Ltd.

C14 Grant of patent or utility model
GR01 Patent grant