使用ffmpeg+nginx将rtmp直播流转为hls直播流

ffmpeg的安装和nginx的安装在之前的博客中有详细的讲解。

mac搭建nginx+rtmp直播流

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后面配置的路径丢弃掉,把当前匹配到的目录指向到指定的目录。

posted on 2023-11-10 22:33  卖小女孩的小男孩  阅读(462)  评论(0)    收藏  举报