分享

HLS实现点播和直播时,M3U8文件的不同

 心灵地图sxh 2018-07-18

1.问题描述

最近做一个转码切片播放测试,使用HLS(HTTP Live Streaming)来做直播, 每个TS分片时间为10s,根据TS分片文件生成以下live m3u8文件

复制代码
#EXTM3U
#EXT-X-MEDIA-SEQUENCE:1
#EXT-X-TARGETDURATION:10

#EXTINF:10
hls/1.ts
#EXTINF:10
hls/2.ts
#EXTINF:10
hls/3.ts
#EXTINF:10
hls/4.ts
#EXTINF:10
hls/5.ts
#EXTINF:10
hls/6.ts
#EXTINF:10
hls/7.ts
#EXTINF:10
hls/8.ts
#EXTINF:10
hls/9.ts
#EXTINF:10
hls/10.ts
复制代码

 将上述m3u8文件保存为live.m3u8,放到Apache文档目录下,用VLC播放以下网址:

http://localhost/live.m3u8

测试发现,开始播放的第一个文件不是1.ts,多次测试后发现:

只要列表中的文件超过三个,播放的总是列表中的最后三个文件

2.问题解决

很悲惨的是,上网搜索后,没有找到任何有效的信息,有个哥们遇到同样的情况,解决后有没有将经验分享出来。

向一位同事请教后,同事说,这是有可能的,因为live m3u8文件列表是需要实时更新的,我们做测试的话,可以先在最后面加上#EXT-X-ENDLIST,这个方法经测试有效,但这样已经不是live m3u8模式

再次上网搜索后,确认,终于找到一篇live m3u8说明

Live Playlist (Sliding Window)

For live sessions, the index file is updated by removing media URIs from the file as new media files are created and made available.

Important: The EXT-X-ENDLIST tag is not present in the Live playlist, indicating that new media files will be added to the index file as they become available.

See Listing 3 for an example live playlist as it would appear at the beginning of a session.

Listing 3 Live Playlist at the beginning of a session.

复制代码
  1. #EXTM3U
  2. #EXT-X-TARGETDURATION:10
  3. #EXT-X-VERSION:3
  4. #EXT-X-MEDIA-SEQUENCE:1
  5. #EXTINF:10,
  6. fileSequence1.ts
  7. #EXTINF:10,
  8. fileSequence2.ts
  9. #EXTINF:10,
  10. fileSequence3.ts
  11. #EXTINF:10,
  12. fileSequence4.ts
  13. #EXTINF:10,
  14. fileSequence5.ts
复制代码

The EXT-X-MEDIA-SEQUENCE tag value MUST be incremented by 1 for every media URI that is removed from the playlist file. Media URIsmust be removed from the playlist file in the order that they appear in the playlist. The updated index file presents a moving window into a continuous stream. This type of session is suitable for continuous broadcasts.

Here's the same playlist after it has been updated with new media URIs:

Listing 4 Live Playlist after updating the media URIs.

复制代码
  1. #EXTM3U
  2. #EXT-X-TARGETDURATION:10
  3. #EXT-X-VERSION:3
  4. #EXT-X-MEDIA-SEQUENCE:2
  5. #EXTINF:10,
  6. fileSequence2.ts
  7. #EXTINF:10,
  8. fileSequence3.ts
  9. #EXTINF:10,
  10. fileSequence4.ts
  11. #EXTINF:10,
  12. fileSequence5.ts
  13. #EXTINF:10,
  14. fileSequence6.ts
复制代码

3.live m3u8更新规则

live m3u8文件列表需要不断更新,更新规则:

  1. 移除一个文件播放列表中靠前的(认为已播放的)文件
  2. 不断更新EXT-X-MEDIA-SEQUENCE标签,以步长为1进行递增

4.实验

写了一个生成live m3u8的小程序,进行测试

  1. Usage:
  2. m3u8_gen.exe start_num list_count duration filename.m3u8 [prefix]

使用示例:

m3u8_gen.exe 1 3 10 live.m3u8 hls/

生成live.m3u8文件为

复制代码
  1. #EXTM3U
  2. #EXT-X-MEDIA-SEQUENCE:1
  3. #EXT-X-TARGETDURATION:10
  4. #EXTINF:10
  5. hls/1.ts
  6. #EXTINF:10
  7. hls/2.ts
  8. #EXTINF:10
  9. hls/3.ts
复制代码

写一个BAT脚本,每10s循环更新live.m3u8文件

复制代码
@echo off

for /l %%i in (1,1,420) do (
echo m3u8_gen.exe %%i 3 10 live.m3u8 hls/
m3u8_gen.exe %%i 3 10 live.m3u8 hls/
call :SLEEP 10000
)

::延时函数实现
:SLEEP
ping 192.168.11.1 -n 1 -w %1 > nul 
复制代码

经VLC播放测试正常!!



//======================================================================================================

//直播过程中 需要保持实时更新m3u8 文件,也就是一个paylist,服务器如果是8秒一个片,那么每隔5秒就得更新文件,如果之前是

#EXTM3U
#EXT-X-TARGETDURATION:5
#EXT-X-MEDIA-SEQUENCE:912
http://10.10.2.167/t00000000000086/test912.ts
http://10.10.2.167/t00000000000086/test913.ts
http://10.10.2.167/t00000000000086/test914.ts

由于是实时视频,因此不需要加  endlist

文件中总是保存最新三个ts文件,以滑动窗口的方式进行更新,序号如下     (3个文件)

1,2,3

2,3,4

4,5,6

#EXT-X-MEDIA-SEQUENCE:1  ,下一次就从 2 开始 依次类推,
客户端也会实时的去请求该  playlist.m3u8,如果有改变 就需要下载该文件,可以查看文件的最后修改日期 

直播过程中,服务器切片ts文件,需要每一个文件的开始是I帧,如何确定

这样就不能保证时间,m3u8文件list的duration


//=======================================================================

为什么会使用ts 封装,而不是MP4,因为 ts 可以无缝拼接,MP4文件不能,而且编码必须是h264 和aac


//hls 推流过程 ;   视频源 推送流给服务器的时候,用的是http协议的 post方法,post的是ts文件


    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多