ffmpeg的安装和nginx的安装在之前的博客中有详细的讲解。
1.配置nginx
(1)配置rtmp直播
rtmp {
server {
listen 1935;
application myapp {
live on;
#record keyframes;
#record_path /tmp;
#record_max_size 128K;
#record_interval 30s;
#record_suffix .this.is.flv;
#on_publish http://localhost:8080/publish;
#on_play http://localhost:8080/play;
#on_record_done http://localhost:8080/record_done;
}
application live {
live on; #开启实时
hls on; #开启hls
hls_path /usr/local/etc/nginx/html/multimedia/hls; #hls的ts切片存放路径
hls_fragment 2s; #本地切片长度
hls_playlist_length 6s; #HLS播放列表长度
}
}
(2)配置hls拉流
-
这个配置为了
客户端
能够以http协议获取HLS的拉流
location /live {
types {
application/vnd.apple.mpegurl m3u8;
video/mp2t ts;
}
alias /usr/local/etc/nginx/html/multimedia/hls/;
add_header Cache-Control no-cache;
}
(3)重启nginx
sudo nginx -s reload
2.推流测试
这里我们找了一个正在直播中的rtmp拉流地址
rtmp://liveplay.dayukeji.xin/live/54260_WBH20190810095219929830
然后用ffmpeg进行推流
ffmpeg -re -i rtmp://liveplay.dayukeji.xin/live/54260_WBH20190810095219929830 -vcodec libx264 -vprofile baseline -acodec libmp3lame -ar 44100 -ac 1 -f flv rtmp://127.0.0.1:1935/live/room8
然后我们可以在nginx中配置的路径下看到一个个的ts文件和m3u8文件
3.测试拉流
通过上面的配置,我们可以hls播放方式来看到推出来的流。注意,如果使用 http 方式,则是监听的 8080 端口。
在Safari浏览器或者vlc中打开如下链接
http://127.0.0.1:8080/live/room8.m3u8
可以看到手机端推送的直播在电脑上显示出来了
·
4.补充知识
Nginx的alias指令和root指令的用法
root与alias主要区别在于nginx如何解释location后面的uri,这会使两者分别以不同的方式将请求映射到服务器文件上。
oot的处理结果是:root路径+location路径
alias的处理结果是:使用alias路径替换location路径
alias是一个目录别名的定义,root则是最上层目录的定义。
还有一个重要的区别是alias后面必须要用“/”结束,否则会找不到文件的。。。而root则可有可无~~
root实例:
location /t {
root /www/root/html/;
}
如果一个请求的URI是/t/a.html时,web服务器将会返回服务器上的/www/root/html/t/a.html的文件。
alias实例:
location /hls{
alias /usr/local/etc/nginx/html/multimedia/hls/;
}
如果一个请求的URI是/hls/a.html时,web服务器将会返回服务器上的/usr/local/etc/nginx/html/multimedia/hls/a.html的文件。alias会把location后面配置的路径丢弃掉,把当前匹配到的目录指向到指定的目录。