【WebRTC】開源項目Webrtc-streamer介紹

WebRTC-Streamer

這是一個用于通過簡單的信令機制(參見 api)流式傳輸 WebRTC 媒體源的實驗項目,支持以下媒體源:

  • 捕獲設備

  • 屏幕捕獲

  • mkv 文件

  • RMTP/RTSP 源

同時該項目也兼容 WHEP 接口。


注意 * 在線演示已停止,直到遷移到歐洲的 Web 托管服務。

資源

  • 源碼包 https://github.com/mpromonet/webrtc-streamer/releases/latest
  • docker容器 https://hub.docker.com/r/mpromonet/webrtc-streamer

使用

./webrtc-streamer [-H http port] [-S[embeded stun address]] -[v[v]]  [urls...]
./webrtc-streamer [-H http port] [-s[external stun address]] -[v[v]] [urls...]
./webrtc-streamer -V
主要參數:
-v[v[v]] : 設置詳細程度(verbosity)
-V : 打印版本信息
-C config.json : 從JSON配置文件加載urls
-n 名稱 -u 視頻url -U 音頻url : 為視頻url和音頻url注冊名稱
[url] : 注冊到源列表的url
HTTP服務器配置:
-H [主機名:]端口 : HTTP服務器綁定(默認0.0.0.0:8000)
-w web根目錄 : 獲取文件的路徑
-c ssl密鑰證書 : HTTPS的私鑰和證書路徑
-N 線程數 : HTTP服務器的線程數
-A 密碼文件 : HTTP服務器訪問的密碼文件
-D 認證域 : HTTP服務器訪問的認證域(默認:mydomain.com)
STUN/TURN服務器配置:
-S[stun地址] : 啟動嵌入式STUN服務器綁定到地址(默認0.0.0.0:3478)
-s[stun地址] : 使用外部STUN服務器(默認:stun.l.google.com:19302,-表示不使用STUN)
-T[用戶名:密碼@]turn地址 : 啟動嵌入式TURN服務器(默認:禁用)
-t[用戶名:密碼@]turn地址 : 使用外部TURN中繼服務器(默認:禁用)
其他配置:
-R [Udp端口范圍最小:最大] : 設置webrtc udp端口范圍(默認0:65535)
-W webrtc_trials_fields : 設置webrtc trials字段(默認:WebRTC-FrameDropper/Disabled/)
-a[音頻層] : 指定要使用的音頻捕獲層(默認:0)
-q[過濾器] : 指定發布過濾器(默認:.)
-o : 使用空編解碼器(保持幀編碼)

-H 參數會被轉發到 civetweb 的
listening_ports選項
允許使用 civetweb 的語法,例如 -H8000,9000 或 -H8080r,8443s

使用 -o 選項允許使用 webrtc::VideoFrameBuffer::Type::kNative 存儲來自后端流的壓縮幀數據。這通過重寫 webrtc::VideoFrameBuffer 結構,將數據存儲在 i420 緩沖區的覆蓋中來實現。這允許將 H264 幀從 V4L2 設備或 RTSP 流轉發到 WebRTC 流。它使用更少的 CPU,但功能較少(調整大小、編解碼器和帶寬控制被禁用)。

WebRTC 流名稱的選項:

  • 使用 -n 參數定義的別名,然后對應的 -u 參數將用于創建捕獲器

  • “rtsp://” URL,將使用基于 live555 的 RTSP 捕獲器打開

  • “file://” URL,將使用基于 live555 的 MKV 捕獲器打開

  • “rmtp://” URL,將使用基于 librmtp 的 RMTP 捕獲器打開

  • “screen://” URL,將由 webrtc::DesktopCapturer::CreateScreenCapturer 打開

  • “window://” URL,將由 webrtc::DesktopCapturer::CreateWindowCapturer 打開

  • “v4l2://” URL,將捕獲 H264 幀并使用 webrtc::VideoFrameBuffer::Type::kNative 類型存儲(在 Windows 上不支持)

  • “videocap://” URL,視頻捕獲設備名稱

  • “audiocap://” URL,音頻捕獲設備名稱

Examples
./webrtc-streamer -C config.json

我們可以通過以下方式訪問 WebRTC 流:Live Demo

使用 webrtcstreamer.html 頁面。例如:

  • webrtcstreamer.html?rtsp://wowzaec2demo.streamlock.net/vod/mp4:BigBuckBunny_115k.mov

  • webrtcstreamer.html?Bunny

使用 layout=<行數>x<列數> 選項可以顯示 WebRTC 流的網格布局。例如:Live Demo

使用docker鏡像

您可以使用 docker 鏡像啟動應用程序:

docker run -p 8000:8000 -it mpromonet/webrtc-streamer

您可以通過以下方式從主機暴露 V4L2 設備:

docker run --device=/dev/video0 -p 8000:8000 -it mpromonet/webrtc-streamer

容器入口點是 webrtc-streamer 應用程序,然后您可以:

  • 查看所有命令

    docker run -p 8000:8000 -it mpromonet/webrtc-streamer --help
    
  • 運行容器并注冊 RTSP URL:

    docker run -p 8000:8000 -it mpromonet/webrtc-streamer -n raspicam -u rtsp://pi2.local:8554/unicast
    
  • 運行容器并提供 config.json 文件:

    docker run -p 8000:8000 -v $PWD/config.json:/usr/local/share/webrtc-streamer/config.json mpromonet/webrtc-streamer
    

在 NAT 后使用嵌入式 STUN/TURN 服務器

It is possible to start an embeded STUN
and TURN
server and publish its URL:

./webrtc-streamer -S0.0.0.0:3478 -s$(curl -s ifconfig.me):3478
./webrtc-streamer -s- -T0.0.0.0:3478 -tturn:turn@$(curl -s ifconfig.me):3478
./webrtc-streamer -S0.0.0.0:3478 -s$(curl -s ifconfig.me):3478 -T0.0.0.0:3479 -tturn:turn@$(curl -s ifconfig.me):3479

The command curl -s ifconfig.me is getting the public IP, it could also given
as a static parameter.

In order to configure the NAT rules using the upnp feature of the router, it is
possible to use
upnpc like
this:

upnpc -r 8000 tcp 3478 tcp 3478 udp

Adapting with the HTTP port, STUN port, TURN port.

HTML Embedding

不使用內部 HTTP 服務器,也可以很容易地在由其他 HTTP 服務器提供的 HTML 頁面中顯示 WebRTC 流。在創建 WebRtcStreamer 實例時,需要提供要使用的 WebRTC-streamer 的 URL:WebRtcStreamer
例如:

var webRtcServer = new WebRtcStreamer(<video tag>, <webrtc-streamer url>);

一個簡短的示例 HTML 頁面,使用在本地 8000 端口運行的 webrtc-streamer:

<html>
<head>
<script src="libs/adapter.min.js" ></script>
<script src="webrtcstreamer.js" ></script>
<script>        var webRtcServer      = null;window.onload         = function() { webRtcServer      = new WebRtcStreamer("video",location.protocol+"//"+location.hostname+":8000");webRtcServer.connect("rtsp://wowzaec2demo.streamlock.net/vod/mp4:BigBuckBunny_115k.mov");}window.onbeforeunload = function() { webRtcServer.disconnect(); }
</script>
</head>
<body> <video id="video" />
</body>
</html>

使用 WebComponents

WebRTC-streamer 提供了一個 WebComponent 來簡化 HTML 頁面中的流顯示。這個組件可以像這樣使用:
Web Components

<html>
<head><script type="module" src="webrtc-streamer-element.js"></script>
</head>
<body><webrtc-streamer url="rtsp://wowzaec2demo.streamlock.net/vod/mp4:BigBuckBunny_115k.mov"></webrtc-streamer>
</body>
</html>

這個 WebComponent 提供了以下屬性:

  • url: 要顯示的流 URL

  • options: 包含以下選項的 JSON 字符串:

  • video: 布爾值,是否顯示視頻

  • audio: 布爾值,是否播放音頻

  • autoplay: 布爾值,是否自動播放

  • muted: 布爾值,是否靜音

  • controls: 布爾值,是否顯示控制條

  • poster: 字符串,視頻封面圖片 URL

這個組件會自動處理 WebRTC 連接的建立和斷開,使得在 HTML 頁面中集成 WebRTC 流變得非常簡單。Live Demo

可以使用 webcomponent 作為視頻流的容器:Live Demo

使用 WHEP

WHEP (WebRTC-HTTP Egress Protocol) 是一種基于 HTTP 的協議,用于從 WebRTC 服務器獲取媒體流。WebRTC-streamer 支持 WHEP 接口。WHEP

WebRTC player 可以顯示來自 webrtc-streamer 的 WebRTC 流.

一個最簡化的例子: Live Demo

<html>
<head><script src="https://unpkg.com/@eyevinn/whep-video-component@latest/dist/whep-video.component.js"></script>
</head>
<body><whep-video id="video" muted autoplay></whep-video><script>video.setAttribute('src', `${location.origin}/api/whep?url=Asahi&options=rtptransport%3dtcp%26timeout%3d60`);</script>
</body>
</html>

使用 tensorflow.js 進行物體檢測

Live Demo

連接到 Janus Gateway 視頻房間。

Janus Gateway
JanusVideoRoom

var janus = new JanusVideoRoom(<janus url>, <webrtc-streamer url>)
<html>
<head>
<script src="janusvideoroom.js" ></script>
<script>        var janus = new JanusVideoRoom("https://janus.conf.meetecho.com/janus", null);janus.join(1234, "rtsp://pi2.local:8554/unicast","pi2");janus.join(1234, "rtsp://wowzaec2demo.streamlock.net/vod/mp4:BigBuckBunny_115k.mov","media");	    
</script>
</head>
</html>

連接到 Jitsi 會議

XMPPVideoRoom

var xmpp = new XMPPVideoRoom(<xmpp server url>, <webrtc-streamer url>)
<html>
<head>
<script src="libs/strophe.min.js" ></script>
<script src="libs/strophe.muc.min.js" ></script>
<script src="libs/strophe.disco.min.js" ></script>
<script src="libs/strophe.jingle.sdp.js"></script>
<script src="libs/jquery-3.5.1.min.js"></script>
<script src="xmppvideoroom.js" ></script>
<script>        var xmpp = new XMPPVideoRoom("meet.jit.si", null);xmpp.join("testroom", "rtsp://wowzaec2demo.streamlock.net/vod/mp4:BigBuckBunny_115k.mov","Bunny");	    
</script>
</head>
</html>

Live Demo

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/900695.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/900695.shtml
英文地址,請注明出處:http://en.pswp.cn/news/900695.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【Java設計模式】第9章 原型模式講解

9. 原型模式 9.1 原型模式講解 定義:通過拷貝原型實例創建新對象,無需調用構造函數。特點: 創建型模式無需了解創建細節適用場景: 類初始化消耗資源多對象創建過程繁瑣(如屬性賦值復雜)循環體中需創建大量對象優點: 性能優于直接new簡化創建流程缺點: 必須實現clone()…

【Java集合】LinkedList源碼深度分析

參考筆記&#xff1a;java LinkedList 源碼分析&#xff08;通俗易懂)_linkedlist源碼分析-CSDN博客 目錄 1.前言 2.LinkedList簡介 3.LinkedList的底層實現 4.LinkedList 與 ArrayList 的對比 4.1 如何選擇 4.2 對比圖 5.LinkedList 源碼Debug 5.1 add(E e) &#xff…

openssl源碼分析之加密模式(modes)

openssl實現分組加密模式&#xff08;例如AES128-CBC的CBC部分&#xff09;的模塊名字叫做modes&#xff0c;源代碼位于 https://gitee.com/gh_mirrors/openssl/tree/master/crypto/modes 博主又打不開github了TT&#xff0c;只能找個gitee鏡像 頭文件是modes.h。 該模塊目前…

Java 搭建 MC 1.18.2 Forge 開發環境

推薦使用 IDEA 插件 Minecraft Development 進行創建項目 創建完成后即可進行 MOD 開發。 但是關于 1.18.2 的開發教程太少&#xff0c;因此自己研究了一套寫法&#xff0c;寫法并非是最優的但是是探索開發MOD中的一次筆記和記錄 GITHUB: https://github.com/zimoyin/zhenfa…

nginx如何實現負載均衡?

Nginx 是一款高性能的 Web 服務器和反向代理服務器&#xff0c;它可以通過配置實現負載均衡功能。以下是實現負載均衡的詳細步驟和方法&#xff1a; 1. 基本概念 負載均衡是將客戶端請求分發到多個后端服務器上&#xff0c;以提高系統的可用性和性能。Nginx 支持多種負載均衡策…

深度學習天崩開局

李沐大神的d2l包導入&#xff0c; 這玩意需要python311版本&#xff0c;我現在版本已經313了&#xff0c;作為一個天生要強的男人&#xff0c;我是堅決不向低版本低頭的。 然后我就研究啊&#xff0c;各種翻資料啊&#xff0c;然后deepseek加豆包都翻爛了&#xff0c; 最終所…

docker部署jenkins并成功自動化部署微服務

一、環境版本清單&#xff1a; docker 26.1.4JDK 17.0.28Mysql 8.0.27Redis 6.0.5nacos 2.5.1maven 3.8.8jenkins 2.492.2 二、服務架構&#xff1a;有gateway&#xff0c;archives&#xff0c;system這三個服務 三、部署步驟 四、安裝linux 五、在linux上安裝redis&#…

MPDrive:利用基于標記的提示學習提高自動駕駛的空間理解能力

25年4月來自南方科技大學、百度、英國 KCL和琶洲實驗室&#xff08;廣東 AI 和數字經濟實驗室&#xff09;的論文“MPDrive: Improving Spatial Understanding with Marker-Based Prompt Learning for Autonomous Driving”。 自動駕駛視覺問答&#xff08;AD-VQA&#xff09;…

Halcon圖像采集

Halcon是一款強大的機器視覺軟件&#xff0c;結合C#可以開發出功能完善的視覺應用程序。 基本設置 確保已經安裝了Halcon和Halcon的.NET庫&#xff08;HalconDotNet&#xff09;。 1. 添加引用 在C#項目中&#xff0c;需要添加對HalconDotNet.dll的引用&#xff1a; 右鍵點…

Win10定時任務計劃無法顯示要執行的EXE任務程序界面,問題解決辦法

用C#開發的一款WINFORM程序&#xff0c;在電腦測試一切順利&#xff0c;運行結果正確。但用電腦的定時任務執行時&#xff0c;程序界面不顯示&#xff0c;重啟電腦、各種試都不行&#xff0c;最終問題解決。 解決辦法&#xff1a; 要選“只在用戶登陸時運行”&#xff0c;才能執…

Navicat和PLSQL在oracle 使用語句報ORA-00911: 無效字符

后面我發現可能是在復制SQL語句中有中文&#xff0c;但是環境變量未配置中文環境。 因為Oracle的語法解析器特別嚴格&#xff0c;就會報出以上的錯誤出來。 SQL語句錯誤&#xff0c;存在中文字符或者sql語句空格導致&#xff0c;去掉即可解決。 我重新寫語句&#xff0c;發現…

[ctfshow web入門] web30

信息收集 題目將flag system php不區分大小寫地過濾了 解題 前置知識 print_r&#xff1a;php中用于打印數組 scandir&#xff1a;php中用于獲取指點目錄下的所以文件目錄名 getcwd&#xff1a;獲取當前目錄 目錄獲取 這里提供兩種方法 print_r(scandir(getcwd())); pri…

linux下MMC_TEST的使用

一:打開如下配置,將相關文件編譯到內核里: CONFIG_MMC_TEST CONFIG_MMC_DEBUG CONFIG_DEBUG_FS二:將mmc設備和mmc_test驅動進行綁定 2.1查看mmc設備編號 ls /sys/bus/mmc/drivers/mmcblk/mmc0:aaaa2.2將mmc設備與原先驅動進行解綁 echo mmc0:aaaa >

《深度解析LightGBM與MySQL數據集成:高效機器學習的新范式》

在機器學習工程實踐中&#xff0c;數據與模型的高效交互一直是制約算法性能發揮的關鍵瓶頸。LightGBM作為梯度提升決策樹框架的杰出代表&#xff0c;其與關系型數據庫MySQL的深度集成能力&#xff0c;為數據科學家提供了從原始數據到預測結果的完整解決方案。這種集成不是簡單的…

處理Excel的python庫openpyxl、xlrd、xlwt、pandas有什么區別,搞懂它

openpyxl、xlrd、xlwt、pandas 都能處理 Excel 表格&#xff0c;但用途和適合的場景不同。今天做個總結&#xff1a; 庫名功能支持格式讀寫支持樣式備注openpyxl全面的.xlsx處理庫.xlsx&#xff08;Excel2007&#xff09;???首選xlrd讀取.xls文件的老牌工具.xls&#xff08…

EasyExcel-一款好用的excel生成工具

EasyExcel是一款處理excel的工具類&#xff0c;主要特點如下&#xff08;官方&#xff09;&#xff1a; 特點 高性能讀寫&#xff1a;FastExcel 專注于性能優化&#xff0c;能夠高效處理大規模的 Excel 數據。相比一些傳統的 Excel 處理庫&#xff0c;它能顯著降低內存占用。…

視頻分析設備平臺EasyCVR攜手高空拋物AI智能分析技術,打造住宅小區頭頂安全智能防線

一、背景介紹 隨著城市化進程的高速推進&#xff0c;城市天際線不斷被刷新&#xff0c;高樓大廈密密麻麻。然而&#xff0c;高空拋物問題也逐漸顯現&#xff0c;這一行為不僅嚴重影響城市文明的形象&#xff0c;更帶來很多安全隱患&#xff0c;威脅居民的生命財產安全&#xf…

Spring MVC 操作會話屬性詳解(@SessionAttributes 與 @SessionAttribute)

Spring MVC 操作會話屬性詳解&#xff08;SessionAttributes 與 SessionAttribute&#xff09; 1. 核心注解對比 注解作用范圍功能SessionAttributes類級別聲明控制器中需要持久化的模型屬性&#xff08;存入 HttpSession&#xff09;SessionAttribute方法參數/返回值顯式綁定…

Python字典實戰: 三大管理系統開發指南(班級+會議+購物車)(附源碼)

目錄 摘要 一、班級管理系統&#xff08;含成績模塊&#xff09; 1. 功能概述 2. 完整代碼與解析 3. 代碼解析與亮點 二、會議管理系統 1. 功能概述 2. 完整代碼 3. 代碼解析與亮點 三、購物車管理系統 1. 功能概述 2. 完整代碼 3. 代碼解析與亮點 四、總結與擴…

北京自在科技:讓萬物接入蘋果Find My網絡的″鑰匙匠″

在AirTag掀起全球防丟熱潮的今天&#xff0c;越來越多的第三方產品開始接入蘋果Find My網絡——從充電寶到電動車&#xff0c;從行李箱到保溫杯&#xff0c;用戶只需打開iPhone的「查找」App&#xff0c;就能實時定位這些物品。 北京自在科技有限責任公司早在蘋果推出Find My開…