iOS直播--Nginx服务器搭建和RTMP,HLS推流实现
iOS直播--Nginx服务器搭建和RTMP,HLS推流实现
她吃西红柿 发表于4个月前
iOS直播--Nginx服务器搭建和RTMP,HLS推流实现
  • 发表于 4个月前
  • 阅读 1534
  • 收藏 98
  • 点赞 1
  • 评论 9

腾讯云 十分钟定制你的第一个小程序>>>   

Nginx介绍

Nginx ("engine x") 是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP服务器。Nginx是由Igor Sysoev为俄罗斯访问量第二的Rambler.ru站点开发的,第一个公开版本0.1.0发布于2004年10月4日。其将源代码以类BSD许可证的形式发布,因它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名。2011年6月1日,nginx 1.0.4发布。 Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行。由俄罗斯的程序设计师Igor Sysoev所开发,供俄国大型的入口网站及搜索引擎Rambler(俄文:Рамблер)使用。其特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。

简言之,Nginx本身是一个非常出色的HTTP服务器,具有占用内存少,高并发的特点。

安装

brew install nginx-full --with-rtmp-module

验证

终端输入 nginx 启动服务器
在浏览器中输入:http://localhost:8080,如下图,则开启成功。

输入图片说明

配置文件路径(/usr/local/etc/nginx/nginx.conf)
配置Nginx

//支持hls 
location /hls {
        #Serve HLS config
        types {
            application/vnd.apple.mpegurl    m3u8;
            video/mp2t ts;
        }
        root /usr/local/var/www;
        add_header Cache-Control    no-cache;
    }
//支持rtmp
rtmp {
    server {
        listen 1935;
        application rtmplive {
            live on;
            max_connections 1024;
        }
        application hls{
            live on;
            hls on;
            hls_path /usr/local/var/www/hls;
            hls_fragment 1s;
        }
    }
}
   

拷贝到如图位置

输入图片说明

输入图片说明

具体参数可以参考官方文档
/usr/local/Cellar/rtmp-nginx-module/1.1.7.11-dev_1/share/rtmp-nginx-module/README.md

注意:修改nginx.conf之后,需重启nginx服务,才会生效:$nginx -s reload。 再次在浏览器中测试:http://localhost:8080,以确认nginx开启的状态。
不了解RTMP和HLS协议的同学请参考 流媒体协议
安装ffmpeg

brew install ffmpeg

###RTMP推流

ffmpeg -re -i xxx你的文件.mp4 -vcodec libx264 -vprofile baseline -acodec aac -ar 44100 -strict -2 -ac 1 -f flv -s 1280x720 -q 10 rtmp://localhost/rtmplive/demo
//注意这里的目录rtmplive要和配置文件中 application 后面的名字一样

输入图片说明

如显示上图表示推流成功, 可以用VLC下载链接播放器打开,延迟大概在3s~5s左右输入图片说明

HLS推流

ffmpeg -re -i xxx.mp4 -vcodec libx264 -vprofile baseline -acodec aac -ar 44100 -strict -2 -ac 1 -f flv -s 1280x720 -q 10 rtmp://localhost:1935/hls/demo
http://localhost:8080/hls/demo.m3u8

HLS流可以用VLC打开 也可以直接用Safari打开

输入图片说明

由于HLS流需要先下载索引,延迟较高

共有 人打赏支持
粉丝 32
博文 42
码字总数 21178
评论 (9)
王枢昊
我想请教一下:基于nginx+ffmpeg切割的点播hls流(用于微信h5)
1.如何动态切割,就是不需要事先把所有mp4文件切割好,等请求的时候判断是否存在m3u8再切mp4文件。
2.如何管理mp4的m3u8碎片,最好是能定期清理碎片或者是在内存/临时区域存储这些m3u8文件。
滔哥
如果是rtmp的话,延时应该在3秒以内才正常呀。。。
她吃西红柿

引用来自“滔哥”的评论

如果是rtmp的话,延时应该在3秒以内才正常呀。。。
公司网络比较卡
她吃西红柿

引用来自“王枢昊”的评论

我想请教一下:基于nginx+ffmpeg切割的点播hls流(用于微信h5)
1.如何动态切割,就是不需要事先把所有mp4文件切割好,等请求的时候判断是否存在m3u8再切mp4文件。
2.如何管理mp4的m3u8碎片,最好是能定期清理碎片或者是在内存/临时区域存储这些m3u8文件。
:flushed:我看7牛是切好了多个码率的文件,如果要动态的话应该也是客户端动态提交带宽环境然后返回对应的流, 仅参考
王枢昊

引用来自“王枢昊”的评论

我想请教一下:基于nginx+ffmpeg切割的点播hls流(用于微信h5)
1.如何动态切割,就是不需要事先把所有mp4文件切割好,等请求的时候判断是否存在m3u8再切mp4文件。
2.如何管理mp4的m3u8碎片,最好是能定期清理碎片或者是在内存/临时区域存储这些m3u8文件。

引用来自“Royce她吃西红柿”的评论

:flushed:我看7牛是切好了多个码率的文件,如果要动态的话应该也是客户端动态提交带宽环境然后返回对应的流, 仅参考
嗯,是客户端提供当前网络环境。我就是想知道如何在nginx动态切,我记得nginx rtmp模块安装后好像有个exec配置节点,用于执行ffmpeg。不知道点播的hls是否可以这样?
泥人张
好文章,我自己动手试了一次没有问题。
但是。。。我在试用obs软件做推流的时候,有一个流名称,我不知道怎么回事。导致试用obs推流失败。
错误信息是无法指定的频道或流秘钥。求解决。
她吃西红柿

引用来自“泥人张”的评论

好文章,我自己动手试了一次没有问题。
但是。。。我在试用obs软件做推流的时候,有一个流名称,我不知道怎么回事。导致试用obs推流失败。
错误信息是无法指定的频道或流秘钥。求解决。
设置里面的流秘钥其实就是一个文件路径,拼接在推流URL后面,例如 rtmp://localhost:1935/rtmplive/流秘钥
拉流的时候也是这个地址
泥人张

引用来自“泥人张”的评论

好文章,我自己动手试了一次没有问题。
但是。。。我在试用obs软件做推流的时候,有一个流名称,我不知道怎么回事。导致试用obs推流失败。
错误信息是无法指定的频道或流秘钥。求解决。

引用来自“她吃西红柿”的评论

设置里面的流秘钥其实就是一个文件路径,拼接在推流URL后面,例如 rtmp://localhost:1935/rtmplive/流秘钥
拉流的时候也是这个地址
非常感谢。理解了,:kissing_heart:
程序猿流川枫
楼主有没测试过正常使用情况下服务器cpu占用率?之前测试ffmpeg解码cpu直接99%
×
她吃西红柿
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: