快速集成iOS基於RTMP的視頻推流


前言

這篇blog是iOS視頻直播初窺:<喵播APP>的一個補充. 因為之前傳到github上的項目中沒有集成視頻的推流.有很多朋友簡信微博上問我推流這部分怎么實現的. 所以, 我重新集成了RTMP的推流, 合並到了之前的項目中.

下載鏈接

github(完整版視頻直播)

blog詳解(建議大家結合這篇一起看)

Mac搭建nginx+rtmp服務器

我個人電腦里面很早以前就搭建過nginx+rtmp服務器, 但是昨天在公司電腦上搭建的時候, 手動輸入命令的時候, 還是出現了bug(所以, 建議大家直接復制命令, 不要手動輸入命令). 所以記錄一份詳細的搭建步驟, 防止再次跳坑...
此段教程參考自推酷:Mac搭建nginx+rtmp服務器

    1. 打開終端, 查看是否已經安裝了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文件所在位置


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
    1. 安裝ffmpeg

執行命令

brew install ffmpeg

安裝ffmpeg時間就要長一點了. 如果速度過慢, 建議翻牆. 不過也才50多M的東西, 耐心一點就好. 等待的時間里, 再安裝一個支持rtmp協議的視頻播放器VLC

    1. 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

簡書



 

 

文/Monkey_ALin(簡書作者)
原文鏈接:http://www.jianshu.com/p/8ea016b2720e
著作權歸作者所有,轉載請聯系作者獲得授權,並標注“簡書作者”。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM