iOS 直播推流 - 搭建基于RTMP的本地Nginx服务器

 

前端时间,公司要调研直播相关的内容,特意花时间进行了一番调研。前端

本篇将记录其中的推流篇-本地推理播放测试。nginx

 

关于Nginx:git

配置Nginx以支持HLS、RTMP的推流与拉流,iOS系统使用LFLiveKit推流,OS X系统使用FFmpeg推流,拉流端能够使用Safari浏览器或者VLC播放器。

下面的例子会就本地视频推流和手机录屏推流分别列举。github

 

Mac搭建nginx+rtmp服务器

  • 打开终端, 查看是否已经安装了Homebrew, 直接终端输入命令
man brew

若是Mac已经安装了homebrew, 会显示一些命令的帮助信息. 此时输入Q退出便可, 直接进入第二步.web

反之, 若是没有安装homebrew,执行命令vim

ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"

若是安装后, 想要卸载homebrew浏览器

ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/uninstall)"
  • 2.安装nginx

先clone nginx项目到本地ruby

brew tap homebrew/nginx

执行安装:bash

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

此时, nginx和rtmp模块就安装好了
输入命令:服务器

nginx

在Safari浏览器里打开http://localhost:8080
若是出现下图, 则表示安装成功


安装成功

若是终端上提示

  • 3.配置nginx和ramp
    首先咱们查看nginx安装到哪了
--with-rtmp-modulebrew info nginx-full

如图, 找到nginx.conf文件所在位置


nginx.conf

经过vim或者点击Finder->前往->前往文件夹->输入/usr/local/etc/nginx/nginx.conf->用记事本工具(推荐Sublime Text2)打开nginx.conf.

直接滚到最后一行, 在最后一个}(即最后的空白处, 没有任何{})后面添加

# 在http节点后面加上rtmp配置:
rtmp {
    server {
        listen 1935;
        application rtmplive {
            live on;
            record off;
        }
    }
}

 四、修改完,cong文件后要重启

nginx -s reload

若是在修改配置文件,重启遇到
[error] open() "/usr/local/var/run/nginx.pid" failed
能够用下面的命令从新加载配置
nginx -c /usr/local/etc/nginx/nginx.conf

 

到了这里就开始分两种状况了

1-本地mac推流
2-手机直接录屏推流

 

第一个,咱们先测试本地视频推流,本地推咱们能够使用ffmpeg实现

一、安装ffmpeg:

brew install ffmpeg

耗时有点久,网速很差可能要10分钟左右

 

二、本地查看推流,这里推荐VLC播放器,支持rtmp协议等等,很是强大。

下载安装完以后,点击 open media  ->  Network   添加播放地址(上面命令的最后一段)

 

三、完成以后,本地找一个mp4视频,放到一个文件夹或桌面

注意:这里推流以前,必须先在vlc添加播放地址,顺序必定要对

ffmpeg -re -i /Users/MACBOOK/Desktop/rtmp/rtmp.mp4 -vcodec libx264 -acodec aac -f flv rtmp://localhost:1935/rtmplive/roomlyj

这段命令,须要改两个地方:

-    /Users/MACBOOK/Desktop/rtmp/rtmp.mp4是你的视频路径

-    rtmp://localhost:1935/rtmplive/roomlyj   这里localhost最好改为你电脑的ip(localhost可能失败),端口号1935和 rtmplive是以前配置文件里定义好的,这里要匹配一致,最后的roomlyj是随便取的名字(roomlyj只要保证地址里两处统一就行)

 

 

推流以后,过几秒,你就能看到播放器弹出窗口播放视频了~~~ 

 

四、最后的重点,若是想在手机端推流,这里咱们须要用到一款第三方框架:LFLiveKit,你们可直接下载Demo运行看看

tip: LFLiveKit已经集成了GPUImage, 若是项目中有集成GPUImage, 须要将以前的移除掉. 且集成LFLiveKit须要关闭Bitcode.

 

下载完成以后,在viewcontroller里,替换一下服务端地址(可直接用上面的本地测试地址)

而后执行同样:

一、先在本地VLC添加播放地址

 

 

二、真机运行demo

三、成功后,视频基本是没有卡顿的,就是与手机画面会有个2~3s延迟。 

 

注意:

真机推流这里可能遇到一个深坑:就是按上面的作法作完以后,vlc不会播放,找了好久,发现是防火墙的缘由

解决:关闭mac本地防火墙就好了。

 

最后若是想关闭本地Nginx服务:

在终端中输入 ps -ef|grep nginx  

获取到nginx的进程号,注意是找到“nginx:master”的那个进程号,以下面的进程好是 61721

再次输入:

kill -QUIT 61721 (从容的中止,即不会马上中止)
Kill -TERM 61721 (马上中止)
Kill -INT 61721 (和上面同样,也是马上中止)

 

 

番外篇:

若是想在mac本地搭服务,能够延伸下:

上面说了:web输入http://localhost:8080 ,能够看到一个页面

若是想放一个视频,咱们依然能够。

步骤:

一、找到nginx本地服务路径

能够输入

/usr/local/Cellar/nginx 

 

好比放一个视频进去,而后浏览器输入地址

http://localhost:8080/rtmp.mp4

就能够播放了

 

相关文章
相关标签/搜索