linux(樹莓派)打造自己的直播

放一下效果圖
PC端

PC端.png

移動(dòng)端


移動(dòng)端.png

這里我們就當(dāng)一些基礎(chǔ)的準(zhǔn)備工作已經(jīng)做好,直接開始直播實(shí)現(xiàn)

1. 技術(shù)準(zhǔn)備

  • node:
    nodeMediaServer(用來(lái)接收流的服務(wù)器)
    NodePlayer.js(視頻播放器)
  • ffmpeg: 推流

2. node

服務(wù)端

  • Node-Media-Server
    我們用它來(lái)做流媒體服務(wù)器
    首先我們先搭建起來(lái)
mkdir nms
cd nms
npm install node-media-server
vi app.js
const NodeMediaServer = require('node-media-server');

const config = {
  rtmp: {
    port: 1935,  // rtmp服務(wù)端口為1935
    chunk_size: 60000,
    gop_cache: true,
    ping: 30,
    ping_timeout: 60
  },
  http: {
    port: 8000, // http-flv的服務(wù)端口為8000
    allow_origin: '*'
  }
};

var nms = new NodeMediaServer(config)
nms.run();

我們需要開放1935跟8000端口(我的防火墻是基于debian的ufw. ubuntu,debian, Raspbian通用)

sudo ufw allow 1935
sudo ufw allow 8000
sudo ufw reload

最后將服務(wù)運(yùn)行起來(lái)

node app.js

出現(xiàn)這個(gè)則說(shuō)明我們運(yùn)行成功了


運(yùn)行成功.png
  1. 客戶端播放器
    NodePlayer.js
    使用方法可以直接看git上作者的demo,淺顯易懂
    DEMO
    直接復(fù)制將websocket地址修改即可
    注:我們?yōu)槭裁从脀ebsocket的方式播放,因?yàn)橹苯硬シ舝tmp流的話需要用到flash, flash在PC端上可以播放,但是在移動(dòng)端卻不能播放,這款插件是跟Node-Media-Server配套的一款視頻播放插件,在上面的Node-Media-Server啟動(dòng)成功的截圖中我們也看到了websocket服務(wù)端口開啟成功的提示,這款插件他就是通過(guò)將rtmp轉(zhuǎn)arraybuffer的方式, 用websocket傳輸給前端,前端通過(guò)canvas顯示視頻的方式來(lái)展示我們的流,這樣的好處在于兼任各種平臺(tái),PC端移動(dòng)端,公眾號(hào)以及各種小程序

3. ffmpeg攝像頭推流

 ffmpeg -re -i /dev/video0 -f flv -vcodec libx164 rtmp://你的推流地址:1935/live/v1

-vcodec libx164
這個(gè)很重要,之前我因?yàn)槿鄙龠@個(gè)參數(shù)導(dǎo)致websocket跟http-flv方式播放流失敗,因?yàn)閒lv播放流需要h264格式, 所以我們加上這個(gè)就可以了

4.最后我們?cè)L問(wèn)NodePlayer播放器頁(yè)面

image.png

出現(xiàn)這個(gè)畫面就是成功了


除了NodePlayer.js外,還有一個(gè)播放器也可以使用,那就是flv.js,這里就不多做描述了

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容