一个直播例子:快速集成iOS基于RTMP的视频推流
效果圖
iTools有點卡, 但是推到服務器倒是很快的.
推流
前言
這篇blog是iOS視頻直播初窺:<喵播APP>的一個補充. 因為之前傳到github上的項目中沒有集成視頻的推流.有很多朋友簡信和微博上問我推流這部分怎么實現的. 所以, 我重新集成了RTMP的推流, 合并到了之前的項目中.
下載鏈接
github(完整版視頻直播)
blog詳解(建議大家結合這篇一起看)
Mac搭建nginx+rtmp服務器
我個人電腦里面很早以前就搭建過nginx+rtmp服務器, 但是昨天在公司電腦上搭建的時候, 手動輸入命令的時候, 還是出現了bug(所以, 建議大家直接復制命令, 不要手動輸入命令). 所以記錄一份詳細的搭建步驟, 防止再次跳坑...
此段教程參考自推酷:Mac搭建nginx+rtmp服務器
- 打開終端, 查看是否已經安裝了Homebrew, 直接終端輸入命令
如果Mac已經安裝了, 會顯示一些命令的幫助信息. 此時輸入Q退出即可, 直接進入第二步.
反之, 如果沒有安裝,執行命令
如果安裝后, 想要卸載
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模塊就安裝好了
輸入命令:
在瀏覽器里打開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安裝到哪了
如圖, 找到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昨天, 就在執行這段命令的時候, 坑出現了.(如果你命令執行成功, 重啟成功了, 沒有沒有任何異常, 請直接跳轉到下一步)
執行命令的時候, 報異常
rtmp成了未知指令. 我趕緊Google, 將其中的答案都試了一遍, 這個bug濤聲依舊. 最后實在沒辦法了,?brew list查看所有安裝的模塊, 才發現是自己手動敲命令的時候, 將nginx-full變成了nginx -full.
上解決方案:
卸載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
簡書
?iOS ? 著作權歸作者所有 舉報文章 關注Monkey_ALin寫了 21333 字,被 3224 人關注,獲得了 1883 個喜歡
文能提筆控蘿莉,武能編碼調BUG如果覺得我的文章對您有用,請隨意打賞。您的支持將鼓勵我繼續創作!
總結
以上是生活随笔為你收集整理的一个直播例子:快速集成iOS基于RTMP的视频推流的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【Windows Tips】关闭 Win
- 下一篇: HTML中span标签使用详解含多种实例