轉自:http://blog.csdn.net/cjsafty/article/details/7922849
簡介:HTTP Live Streaming(縮寫是 HLS)是一個由蘋果公司提出的基於HTTP的流媒體 網絡傳輸協議。
是蘋果公司QuickTime X和iPhone軟件系統的一部分。它的工作原理是把整個流分成一個個小的基於HTTP
的文件來下載,每次只下載一些。當媒體流正在播放時,客戶端可以選擇從許多不同的備用源中以不同的速
率下載同樣的資源,允許流媒體會話適應不同的數據速率。在開始一個流媒體會話時,客戶端會下載一個包
含元數據的extended M3U (m3u8) playlist文件,用於尋找可用的媒體流。
HLS只請求基本的HTTP報文,與實時傳輸協議(RTP)不同,HLS可以穿過任何允許HTTP數據通過的防
火牆或者代理服務器。它也很容易使用內容分發網絡來傳輸媒體流。
此協議詳細內容請參考apple官方網站:https://developer.apple.com/resources/http-streaming/
有兩種方式搭建HLSserver,
一種是利用apple SDK,
一種是利用adobe 的fms,4.5版本支持hls,參考,
adobe的fms現在很強大,但是商用需要licence。有興趣的可以研究下。
一種是利用opensouce.我比較喜歡這一種。
方法:
opensource的方法主要是使用m3u8-segmenter+ffmpeg對ts文件進行分片。
因此思路就是:
1,用編譯好的ffmpeg製作所需要的ts文件,
2,安裝libavformat-dev版本,
3,編譯m3u8-segmenter,
4,部署到nginx
5,高級功能,流切換
6,頁面
過程
1,本來想下載ffmpeg源碼編譯,但是因爲要涉及到faac,x264,lame庫。有時候ffmpeg版本對這些庫的版本又有最低版本要求,在編譯
faac時候遇到以下問題
- 安裝支持庫
- apt-get install automake autoconf m4 libtool
- -bash: ./bootstrap: /bin/sh^M: bad interpreter: No such file or directory
- 轉換字符:
- dos2unix bootstrap
- make
- 錯誤:mpeg4ip.h:126:58: error: new declaration ‘char* strcasestr(const char*, const char*)’
- 解決方法:Remove line 126 containing strcasecmp from mpeg4ip.h as a temporary workaround
- make install時遇到
- usr/local/share/man/man1文件夾無法創建問題。
最後一個問題無法解決,好像是linux(ubuntu)下同一個目錄下,如果已經有一個文件了,則不能創建同名文件夾,遂放棄編譯,
直接從ffmpeg網站:http://ffmpeg.org/download.html ,的linux下載頁面下載編譯好ffmpeg靜態文件。這個靜態文件的主要目的是
爲了把各種文件轉換成apple所規定的文件。所以需要AAC,mp3,x264庫支持。
或者乾脆按照2的方法。apt-get install ffmpeg.這樣會得到ffmpeg可行性文件。
2,安裝ffmpeg支持庫,主要用於編譯m3u8-segmenter,這裏的ffmpeg支持庫,其目的是給segmenter提供libavformat支持。不涉及編解碼。
apt-get install libavformat-dev.
- Reading package lists... Done
- Building dependency tree
- Reading state information... Done
- The following extra packages will be installed:
- libavcodec-dev libavcodec53 libavformat53 libavutil-dev libavutil51 libgsm1 libogg0 liborc-0.4-0
- libschroedinger-1.0-0 libspeex1 libtheora0 libva1 libvorbis0a libvorbisenc2 libvpx1
- Suggested packages:
- libfaad-dev libgsm1-dev libogg-dev libschroedinger-dev libspeex-dev libtheora-dev libvorbis-dev libx11-dev
- libxext-dev libraw1394-dev libdc1394-22-dev speex
- The following NEW packages will be installed:
- libavcodec-dev libavcodec53 libavformat-dev libavformat53 libavutil-dev libavutil51 libgsm1 libogg0 liborc-0.4-0
- libschroedinger-1.0-0 libspeex1 libtheora0 libva1 libvorbis0a libvorbisenc2 libvpx1
這樣會自動安裝ffmepg幾個相關庫。
3,從https://github.com/johnf/m3u8-segmenter 下載m3u8-segmenter
下載後不要用它的反覆編譯,直接取m3u8-segmenter.c文件,
- gcc -Wall -g segmenter.c -o segmenter -lavformat
從源碼來看,因爲只用到了avformat庫,所以只鏈接這一個即可。生成segmenter文件,用help命令,可以看到已經成功。
- HTTP Live Streaming - Segments TS file and creates M3U8 index.
- -i, --input FILE TS file to segment (Use - for stdin)
- -d, --duration SECONDS Duration of each segment (default: 10 seconds)
- -p, --output-prefix PREFIX Prefix for the TS segments, will be appended
- with -1.ts, -2.ts etc
- -m, --m3u8-file FILE M3U8 output filename
- -u, --url-prefix PREFIX Prefix for web address of segments, e.g. http://example.org/video/
- -n, --num-segment NUMBER Number of segments to keep on disk
- -h, --help This help
從上圖來看,語法很簡單,這裏貼一個我用的。
- ./segmenter -i test.ts -n 30 -p sample_test -m stream-test.m3u8 -u http://192.168.1.10:8080/hls/
i表示輸入文件,n表示切割30個,p表示切割文件的前綴。m表示生成的m3u8文件名,u表示這些切割後的文件處於web server的哪個目錄下,這個一定要和web目錄匹配
4,部署到nginx。
nginx的相關部署我在前兩個博客中已經詳細說明,這裏在jwplayer博客的基礎上部署hls。
1)目錄問題:
在html/jwplayer目錄下,建立hls文件夾,將m3u8文件和切割後的全部ts文件拷貝到此目錄下,
在VLC PLAYER或者ipad safie瀏覽器或者在ffplayer(我用的是0.11版本的windows編譯版本)
上的訪問路徑應該是http://192.168.1.10:8080/hls/stream-test.m3u8
2)文件類型問題:編輯 /usr/local/nginx/conf/mime.types 文件,添加如下類型
- application/x-mpegURL m3u8;
- video/MP2T ts;
3)重啓nginx
輸入上述路徑,你應該就看到視頻了。
5,高級功能,流切換
上述m3u8文件,只有一個流,不具備流切換功能。在優酷上,如果是ipad客戶端,可以看到有標清,高清,超清的按鈕,其實那個是對應着不同標準
的(單個)m3u8文件,來實現流切換的,不知道apple是不是這樣做的,apple好像是要求“智能”流切換。即不要求用戶去選擇,而是根據網絡狀況自適應的。
apple給的sample的流切換是把各個流的m3u8寫在一個m3u8文件裏實現的。
類似於這樣,其實原理是一樣的。
- #EXTM3U
- #EXT-X-STREAM-INF:PROGRAM-ID=1, BANDWIDTH=100000
- video1/index1.m3u8
- #EXT-X-STREAM-INF:PROGRAM-ID=1, BANDWIDTH=200000
- video2/index2.m3u8
6,頁面,
如果再繼續搭建一個頁面,把上述地址嵌在頁面裏面,這樣配合CSS就比較美觀了。頁面可以在這個基礎上,用webpy去做。
頁面參考:
蘋果開發網:https://developer.apple.com/resources/http-streaming/
博客:http://www.nginxs.com/linux/459.html
ffmpeg開發網:http://ffmpeg.org/download.html
segmenter源碼:https://github.com/johnf/m3u8-segmenter