前言
這篇blog是iOS視頻直播初窺:<喵播APP>的一個補充. 因為之前傳到github上的項目中沒有集成視頻的推流.有很多朋友簡信
和微博
上問我推流這部分怎么實現的. 所以, 我重新集成了RTMP
的推流, 合並到了之前的項目中.
下載鏈接
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)"
如果安裝后, 想要卸載
ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/uninstall)"
- 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
文件所在位置

通過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推流
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下載地址
聯系我
原文鏈接:http://www.jianshu.com/p/8ea016b2720e
著作權歸作者所有,轉載請聯系作者獲得授權,並標注“簡書作者”。