您的位置:首页 > 移动开发 > IOS开发

快速集成iOS基于RTMP的视频推流

2016-09-27 11:45 309 查看




效果图

iTools有点卡, 但是推到服务器倒是很快的.



推流


前言

这篇blog是iOS视频直播初窥:<喵播APP>的一个补充. 因为之前传到github上的项目中没有集成视频的推流.有很多朋友
简信
微博
上问我推流这部分怎么实现的.
所以, 我重新集成了
RTMP
的推流, 合并到了之前的项目中.


下载链接

github(完整版视频直播)

blog详解(建议大家结合这篇一起看)


Mac搭建nginx+rtmp服务器

我个人电脑里面很早以前就搭建过
nginx+rtmp
服务器, 但是昨天在公司电脑上搭建的时候, 手动输入命令的时候,
还是出现了bug(所以, 建议大家直接复制命令, 不要手动输入命令). 所以记录一份详细的搭建步骤, 防止再次跳坑...

此段教程参考自推酷:Mac搭建nginx+rtmp服务器

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

man brew


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

反之, 如果没有安装,执行命令
ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"[/code] 
如果安装后, 想要卸载
ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/uninstall)"[/code] 2.安装nginx

先clone nginx项目到本地
brew tap homebrew/nginx


执行安装:
brew install nginx-full --with-rtmp-module


此时, nginx和rtmp模块就安装好了

输入命令:
nginx


在浏览器里打开http://localhost:8080

如果出现下图, 则表示安装成功



安装成功

如果终端上提示

nginx: [emerg] bind() to 0.0.0.0:8080 failed (48: Address already in use)

nginx: [emerg] bind() to 0.0.0.0:8080 failed (48: Address already in use)

nginx: [emerg] bind() to 0.0.0.0:8080 failed (48: Address already in use)

nginx: [emerg] bind() to 0.0.0.0:8080 failed (48: Address already in use)

.....

则表示
8080
端口被占用了, 查看端口PID
lsof -i tcp:8080


根据端口PID, kill掉(这儿的
9603
换成你自己
8080
端口的PID)
kill 9603


然后重新执行
nginx
, 打开http://localhost:8080
3.配置nginx和ramp

首先我们查看
nginx
安装到哪了
brew info nginx-full


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



nginx.conf

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

直接滚到最后一行, 在最后一个
}
(即最后的空白处, 没有任何
{}
)后面添加
# 在http节点后面加上rtmp配置:
rtmp {
server {
listen 1935;
application rtmplive {
live on;
record off;
}
}
}


然后重启nginx(其中的1.10.1要换成你自己安装的
nginx
版本号, 查看版本号用
nginx
-v
命令即可)
/usr/local/Cellar/nginx-full/1.10.1/bin/nginx -s reload


昨天, 就在执行这段命令的时候, 坑出现了.(如果你命令执行成功, 重启成功了, 没有没有任何异常, 请直接跳转到下一步)

执行命令的时候, 报异常
nginx: [emerg] unknown directive “rtmp” in /usr/local/etc/nginx/nginx.conf:119


rtmp
成了未知指令. 我赶紧Google, 将其中的答案都试了一遍, 这个bug涛声依旧. 最后实在没办法了, 
brew
list
查看所有安装的模块, 才发现是自己手动敲命令的时候, 将
nginx-full
变成了
nginx
-full
.

上解决方案:

卸载
nginx

brew uninstall nginx


再次安装
nginx

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


安装ffmpeg

执行命令
brew install ffmpeg


安装
ffmpeg
时间就要长一点了. 如果速度过慢, 建议翻墙. 不过也才50多M的东西, 耐心一点就好.
等待的时间里, 再安装一个支持rtmp协议的视频播放器
VLC


ffmpeg推流

以我桌面的一个
loginmovie.mp4
(自己准备一个视频文件, 也可以用我github项目中
Resource
文件下的两个视频文件)为例,
执行推流命令

ffmpeg -re -i /Users/sunlin/Desktop/loginmovie.mp4 -vcodec libx264 -acodec aac -strict -2 -f flv rtmp://localhost:1935/rtmplive/room

将视频推流到服务器后,打开VLC,然后File->open network->输入:

rtmp://localhost:1935/rtmplive/room

效果如图



推流


快速集成直播推流

前提条件:
github上下载最新的喵播项目.
根据上面教程配置好nginx+rtmp服务器

原先准备自己实现一下直播推流,但是今天在技术群聊的时候, 有朋友推荐了优酷土豆旗下
来疯直播
前不久开源的iOS推流框架LFLiveKit.
是用OC写的, 很适合学习(我也准备深入研究一下这个框架, 有什么疑问大家可以一起探讨), 集成也非常简单, 几句代码就OK了.

下载好我写的喵播后, 在Xcode左下方直接搜索
ShowTimeViewController
,
进入
ShowTimeViewController.m
. 搜索
-
(IBAction)living:(UIButton *)sender
, 将里面的
stream.url
替换成你自己的rtmp地址即可.

tip: 
LFLiveKit
已经集成了
GPUImage
,
如果项目中有集成
GPUImage
, 需要将之前的移除掉. 且集成
LFLiveKit
需要关闭
Bitcode
.


结案陈词

现在的喵播算得上是一个比较完整的视频直播项目了, 虽然用了很多第三方, 但是也节省了开发的时间, 提升了开发效率.

后期这个项目我还会不断的完善, 如果你有什么好的idea或者效果, 可以微博私信我, 如果我能搞定, 我会尽快加上去的.


github下载地址

完整版视频直播:喵播下载地址


联系我

github

简书
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: