整体步骤如下:
1. 安装nginx-rtmp-module。
2. 修改nginx配置,普通推拉流设置和权限验证推拉流设置
3. 使用ffmpeg测试推流,使用vlc测试拉流
整个过程中,我会把遇到的坑都重点说一下。因为我自己是从零搭建起,遇到了不少坑。
第一步,安装nginx-rtmp-module
这里我主要讲macos环境配置,其他Linux和Windows环境大家各自百度。在macos遇到的坑,可以借鉴下。
建议全程开启VPN安装。否则安装会非常慢
1.先安装brew,如果本机已安装,则跳过本步骤.安装教程详见官网https://brew.sh/。
2.使用brew安装nginx-rtmp-module,过程如下:
开始我百度的是旧版安装nginx教程,是使用brew在命令行敲入 brew install nginx, 但是这样是不对的。又找了较新的安装教程,安装完发现不兼容。需要把刚才错误的方式安装的nginx给卸载。当然最好还是第一遍直接安装对了。如果本机之前使用老的安装方式,请先卸载。
打开终端,挨个输入如下命令:
命令1:brew tap denji/nginx
命令2:brew install nginx-full --with-rtmp-module
第二步,修改nginx配置。实现简单推流或拉流的验证
macos系统nginx配置路径为:/usr/local/etc/nginx/nginx.conf
建议定位到这个路径,直接使用vscode打开编辑,或者其他文本编辑软件,当然也可以使用vi直接在命令行里面编辑。
1.普通推拉流配置如下:
在配置文件最后面,注意不要放在在http的括号里,黏贴如下配置:
rtmp {
server {
listen 1935;
application live {
live on;
}
}
}
2.权限验证推拉流配置如下:
nginx-rtmp-module默认不限制推流权限、播放权限。如果想加入权限验证,有很多种方法。
下面先说一个最简单的配置方法。
主要是利用on_play或on_publish跳转到当前配置的一个“location”,在这里进行验证。关键点在于rtmp application节点下面要配置“notify_method get;”为什么呢?因为跳转的时候,默认以POST方式传输参数,修改成GET方式,nginx配置里就可以轻松处理了。(当然nginx通过配置文件也可以处理post,只是复杂一些)。
在配置文件最后面,注意不要放在在http的括号里,复制粘贴如下配置:
rtmp {
server {
listen 1935;
notify_method get;
application live {
live on;
on_play http://127.0.0.1:8082/auth; #拉流验证
on_publish http://127.0.0.1:8082/auth; #推流验证
}
}
}
注意此处我是遇到了坑!!
就是127.0.0.1不能写成localhost, 否则使用ffmpeg推流会失败!我各种百度都没找到为啥,最后就随便试了试改成ip了就好用了!!!
另外还要在http的括号范围内的最后下面,添加配置如下:
server {
listen 8082;
location /auth {
if ($arg_pwd = "123456") {
return 200;
}
return 404;
}
}
对于nginx也不了解的人,比如我自己,一开始我都不知道其中arg_pwd的用法是啥,百度了才知道。
$arg_参数名,下划线后面的参数名是表示url问号后面的参数名字。这么写就能直接解析拿到参数,从而进行判断。
此处原理就是使用nginx相应处理on_play和on_publish配置的方法,只要处理成功返回2xx系列的状态即可。一般返回200即可。如果验证错误则直接返回404错误码即可。另外这是直接完全通过nginx处理,也可以指向别的服务器接口地址,只要能够正确验证处理即可。
另外还有其他的两种方法如下:
方法一:修改源码如:
如何给 nginx rtmp 服务加入鉴权机制
http://blog.csdn.net/cui918/article/details/53540397
方法二:修改nginx配置如:
nginx-rtmp-module 权限控制
http://blog.csdn.net/iam_shuaidaile/article/details/50599943
配置好之后,可以启动nginx看一下,启动nginx也可能会遇到错误,一般错误如下:
invalid number of arguments
nginx出现以下的错误,基本上错误的原因就是当前行少了后面的分号导致,一定要写分号。
启动nginx命令很简单,直接在终端输入:nginx 然后回车就好了。
另外如果修改了配置表,重启nginx命令如下:nginx -s reload
可以用浏览器输入地址:http://localhost:8080/ 测试一下nginx是否启动。
查看rtmp端口是否启动,终端输入命令:netstat -an |grep 1935
第三步,配置FFmpeg实现推流。然后使用VLC播放器拉流连接。
1.安装ffmpeg
直接在终端输入命令:brew install ffmpeg
注意ffmpeg安装依赖包不少,如果设置了brew国内镜像,不用开vpn也能比较快,没有设置,还是建议开启vpn安装,能节约不少时间。
首先是ffmpeg普通推流命令,需要配置nginx为普通推拉流配置, 更改配置后请重启nginx
推流一次命令:
ffmpeg -re -i /Users/wz/test.mp4 -vcodec libx264 -acodec aac -f flv rtmp://127.0.0.1:1935/live/test
其中-i后面跟着的是要推流的视频资源路径,flv后面跟着是nginx搭建的rtmp推流地址。地址最后的test名字随便写就好。live就是刚才配置nginx的application后面的名字,注意这个命令是只把指定视频资源推流一次。
循环推流命令:
ffmpeg -re -stream_loop -1 -i /Users/wz/test.mp4 -vcodec libx264 -acodec aac -f flv rtmp://127.0.0.1:1935/live/test
相比推流一次,其实就是多了一个参数-stream_loop -1,-1表示循环无限次,当然你可以指定循环自几次,比如设置2,就是循环两次。
其次是ffmpeg权限验证推流命令,需要nginx为权限验证配置,更改配置后请重启nginx。
推流一次命令:
ffmpeg -re -i /Users/wz/test.mp4 -vcodec libx264 -acodec aac -f flv rtmp://127.0.0.1:1935/live/test?pwd=123456
循环推流命令:
ffmpeg -re -stream_loop -1 -i /Users/wz/test.mp4 -vcodec libx264 -acodec aac -f flv rtmp://127.0.0.1:1935/live/test?pwd=123456
可以看到rtmp连接相比普通推流只增加问号后的一些参数,和普通http连接参数一样。多个参数用&隔开就好。
不过这里注意有个坑是:加上了问号,发现执行命令报错了!!出现了:"zsh: no matches found"的报错,遇到该错误我也是各种百度,最后找到解决方案如下:
1.找到~/.zshrc文件,在其中中加入:setopt no_nomatch
2.执行 source ~/.zshrc
完全关闭终端,再打开重新输入带权限验证的推流命令就可以成功了!
在输入ffmpeg命令遇到上面提到的一个坑是nginx配置里,on_play或on_publish配置地址的时候不能写localhost,要写成127.0.0.1的ip。否则会报错如下:
RTMP_ReadPacket, failed to read RTMP packet header rtmp://localhost:1935/live/test?pwd=123456: Unknown error occurred
另外没有尝试过,域名会不会有问题。如果有问题,建议直接换成对应域名的ip地址。
到此为止搭建nginx-rtmp服务和使用ffmpeg推流已经完成。
接下来可以使用VLC播放器播放一下rtmp的流地址了。如果电脑有其他播放器也可以使用别的播放器。
VLC的官网地址是:https://www.videolan.org/
加了权限验证的链接可以尝试下不加密码参数,应该会提示播放失败。
普通拉流地址:rtmp://127.0.0.1:1935/live/test
权限验证拉流地址: rtmp://127.0.0.1:1935/live/test?pwd=123456