日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何為應(yīng)用程序提供一個(gè)更小更快的視頻通話庫?

LiveVideoStack ? 來源:LiveVideoStack ? 作者:Ishan Khot ? 2021-01-13 14:11 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

在研究如何使視頻通話在未來更高效,更易于擴(kuò)展時(shí),F(xiàn)acebook意識(shí)到,最好的方法是從頭開始重新設(shè)計(jì)庫并重寫整個(gè)庫,也就是Rsys。

我們將在我們的應(yīng)用程序和服務(wù)的所有相關(guān)產(chǎn)品上推出一個(gè)新的視頻通話庫,包括Instagram、Messenger、Portal、Workplace chat等。

通過創(chuàng)建一個(gè)通用類庫足以支持所有這些不同的用例,但我們需要從頭重寫現(xiàn)有庫使用最新版本的開源的WebRTC庫。這是一個(gè)非常令人難以置信的任務(wù),以至于我們整個(gè)公司的工程師都參與到了其中。

與前面的庫相比,Rsys能夠支持多個(gè)平臺(tái),包括Android, iOS, MacOS, Windows和Linux。它的大小大約小了20%,這使得它很容易集成到大小受限的平臺(tái)中,比如Messenger Lite。Rsys擁有大約90%的單元測(cè)試覆蓋率和一個(gè)完整的集成測(cè)試框架,它涵蓋了我們所有的主要調(diào)用場(chǎng)景。

為此,我們通過將庫和體系結(jié)構(gòu)的大小優(yōu)化為二進(jìn)制大小來實(shí)現(xiàn)這一目標(biāo),方法是將調(diào)用所需的部分分成獨(dú)立的獨(dú)立模塊,并利用不依賴于操作系統(tǒng)和環(huán)境的跨平臺(tái)解決方案。

Facebook的視頻通話初始版本是在一個(gè)已有7年歷史的WebRTC分支上編寫的,專門用于在Messenger中啟用本機(jī)音頻通話。當(dāng)時(shí),我們的目標(biāo)是為我們的用戶提供功能最豐富的體驗(yàn)。從那時(shí)起,我們添加了視頻通話,群組通話,視頻聊天引擎和交互式AR效果。每月有數(shù)百萬人使用視頻通話,這個(gè)功能齊全的庫表面上看起來簡(jiǎn)單,但在幕后卻變得復(fù)雜得多。我們有大量特定于Messenger的代碼,這使得我們很難支持像Portal和Instagram這樣的應(yīng)用程序。對(duì)于組調(diào)用和對(duì)等調(diào)用,我們有單獨(dú)的信令協(xié)議,這要求我們編寫兩次特征,并在代碼庫中造成很大的不一致。我們還花費(fèi)了更多的時(shí)間來更新WebRTC的分支,并使用開源的最新改進(jìn)功能。但最后,我們發(fā)現(xiàn)我們?cè)跒榈凸脑O(shè)備和低帶寬場(chǎng)景提供可靠服務(wù)方面落后了。

在研究如何使視頻通話在未來更高效,更易于擴(kuò)展時(shí),我們意識(shí)到,最好的方法是從頭開始重新設(shè)計(jì)庫并重寫整個(gè)庫。結(jié)果就是Rsys,這是一個(gè)視頻通話庫,它讓我們能夠利用自2014年編寫原始庫以來在視頻通話領(lǐng)域取得的一些重大進(jìn)步。與以前的版本相比,Rsys縮小了約20%,并且可在所有開發(fā)中使用平臺(tái)。通過這一新的迭代,我們將重新構(gòu)想我們對(duì)視頻通話平臺(tái)的看法,并從頭開始使用新的客戶端核心和可擴(kuò)展性框架。這有助于我們提升自己的最先進(jìn)技術(shù),新的代碼庫旨在在未來十年保持可持續(xù)性和可擴(kuò)展性,為跨應(yīng)用程序的遠(yuǎn)程存在和互操作性奠定基礎(chǔ)。

更快更小

無論設(shè)備類型或網(wǎng)絡(luò)條件如何,使用較小的代碼庫可以為其用戶實(shí)現(xiàn)更快地加載、更新和啟動(dòng)。相比之下,小型庫也更易于管理、更新、測(cè)試和優(yōu)化。當(dāng)我們開始考慮準(zhǔn)備新的版本時(shí),我們的峰值二進(jìn)制大小已高達(dá)20 MB。盡管我們可以通過編輯一些代碼段來減少一些內(nèi)容,但是要達(dá)到我們想要的效果,我們意識(shí)到我們需要從頭開始重寫整個(gè)代碼庫。

想要獲得較小的庫,最簡(jiǎn)單方法是去掉多年來我們添加的許多功能特征,但是對(duì)我們來說,保留所有最常用的功能(如AR效果)很重要。因此,我們退后一步,研究了如何應(yīng)用過去十年中所學(xué)到的知識(shí)以及我們對(duì)如今使用我們產(chǎn)品的用戶的需求了解。探索完我們的這些選擇之后,我們決定需要越過接口,并深入研究庫本身的基礎(chǔ)結(jié)構(gòu)。

我們做了幾個(gè)架構(gòu)選擇來優(yōu)化大小,引入了一個(gè)即插即用的框架,使用selects有選擇地將特征編譯到需要它們的應(yīng)用程序中,并引入了一個(gè)通用框架來編寫基于Flux架構(gòu)的新特性。我們也從Folly這樣的模板化通用庫轉(zhuǎn)向了像Boost這樣規(guī)模更優(yōu)的庫。SML在所有應(yīng)用程序中實(shí)現(xiàn)大小增益。

最后,我們將核心二進(jìn)制文件的大小減少了大約20%,從大約9MB減少到大約7MB。我們通過重新構(gòu)建我們的特征以適應(yīng)簡(jiǎn)化的體系結(jié)構(gòu)和設(shè)計(jì)來實(shí)現(xiàn)這一點(diǎn)。雖然我們保留了大部分特性,但隨著時(shí)間的推移,我們將繼續(xù)引入更多可插入特性。更少的代碼行數(shù)使代碼庫更輕、更快、更可靠,而精簡(jiǎn)的代碼庫意味著工程師可以更快地進(jìn)行創(chuàng)新。

這項(xiàng)工作的主要目標(biāo)之一是最小化代碼復(fù)雜性和消除冗余。我們知道,一個(gè)統(tǒng)一的體系結(jié)構(gòu)將允許全局優(yōu)化(而不是讓每個(gè)特性都集中在局部?jī)?yōu)化上),并允許代碼重用。為了構(gòu)建這個(gè)統(tǒng)一的體系結(jié)構(gòu),我們做了一些主要的更改:

信令:我們?yōu)樾帕顥L岢隽艘环N狀態(tài)機(jī)架構(gòu),它可以統(tǒng)一對(duì)等調(diào)用和組調(diào)用協(xié)議語義。我們能夠從庫的其余部分抽象出任何特定于協(xié)議的細(xì)節(jié),并提供一個(gè)信令組件,該組件將全權(quán)負(fù)責(zé)在調(diào)用參與者之間協(xié)商共享狀態(tài)。通過減少重復(fù)代碼,我們可以一次編寫特性,并允許輕松更改協(xié)議,并為對(duì)等調(diào)用和組調(diào)用提供統(tǒng)一的用戶體驗(yàn)。

媒體:我們決定重用我們的狀態(tài)機(jī)架構(gòu),并將其應(yīng)用到媒體堆棧中,但這次我們捕獲了開源WebRTC API的語義。同時(shí),我們還致力于用最新版本替換我們的分支版本W(wǎng)ebRTC,同時(shí)保留所有針對(duì)產(chǎn)品的特定優(yōu)化。這使我們能夠在狀態(tài)機(jī)下更改WebRTC版本,只要API本身的語義沒有明顯變化,我們就可以從開放源碼代碼庫中設(shè)置定期常規(guī)拉取。這使我們能夠輕松地更新到最新的功能,而不會(huì)出現(xiàn)任何停機(jī)或延遲。

SDK:為了具有特定于功能的狀態(tài),我們使用Flux架構(gòu)來管理數(shù)據(jù),并為調(diào)用產(chǎn)品提供API,這些API的工作原理類似于web開發(fā)人員熟悉的基于React js的應(yīng)用程序。每個(gè)API調(diào)用都會(huì)導(dǎo)致通過中央調(diào)度程序路由的特定操作。然后,這些動(dòng)作由特定的reducer類處理,并根據(jù)動(dòng)作的類型發(fā)出模型對(duì)象。這些模型對(duì)象被發(fā)送到包含所有特定于功能的業(yè)務(wù)邏輯的網(wǎng)橋,并導(dǎo)致更改模型的后續(xù)操作。最后,所有的模型更新都被發(fā)送到UI,在那里它們被轉(zhuǎn)換成特定于平臺(tái)的視圖對(duì)象進(jìn)行渲染。這使我們能夠清晰地定義一個(gè)包含減速器、橋接器、動(dòng)作和模型的特性,從而使我們能夠在運(yùn)行時(shí)為不同的應(yīng)用程序配置特性。

OS:為了使我們的平臺(tái)具有通用性和可擴(kuò)展性,我們決定抽象出直接依賴于OS的所有功能。我們知道,對(duì)于某些功能(例如創(chuàng)建硬件編碼器,解碼器,線程抽象等),必須具有針對(duì)Android,iOS等的特定于平臺(tái)的代碼,但是我們嘗試為這些功能創(chuàng)建通用接口,以便MacOS和Windows等平臺(tái)可以通過代理對(duì)象提供不同的實(shí)現(xiàn)來輕松插入。我們還大量使用Buck中的cxx_library來以簡(jiǎn)便的方式配置特定于平臺(tái)的庫,以用于編譯器標(biāo)志,鏈接器參數(shù)等。

2dc6f8b8-521b-11eb-8b86-12bb97331649.png

用于調(diào)用的Rsys架構(gòu)

下一步的計(jì)劃

如今,我們的調(diào)用平臺(tái)明顯要小得多,并且能夠在許多不同的用例和平臺(tái)上擴(kuò)展。我們支持每天都有數(shù)百萬人使用的電話。我們的庫是我們所有主要通話應(yīng)用程序的一部分,包括Messenger,Instagram,Portal和Workplacechat。構(gòu)建Rsys需要一個(gè)很長(zhǎng)的過程,但是,對(duì)于使用這些應(yīng)用程序的人們來說,它的感覺并沒有太大不同。它將繼續(xù)為人們提供出色的通話體驗(yàn)。但這僅僅是開始。

我們?cè)赗sys中所做的工作將使我們?cè)谶~向未來的過程中能夠繼續(xù)創(chuàng)新和擴(kuò)展我們的通話體驗(yàn)。除了構(gòu)建可在未來十年或更長(zhǎng)時(shí)間保持可持續(xù)發(fā)展的庫之外,這項(xiàng)工作還為我們所有應(yīng)用的跨應(yīng)用調(diào)用奠定了基礎(chǔ)。它也為我們建立以遠(yuǎn)程存在為中心的環(huán)境奠定了基礎(chǔ)。

這項(xiàng)工作得益于與客戶平臺(tái)團(tuán)隊(duì)合作。我們感謝所有為Rsys做出貢獻(xiàn)的人,特別是Ed Munoz,Hani Atassi,Alice Meng,Shelly Willard,Val Kozina,Adam Hill,Matt Hammerly,Ondrej Lehecka,Eugene Agafonov,Michael Stella,Cameron Pickett,Ian Petersen和Mudit Goel在實(shí)施方面提供了幫助,并繼續(xù)提供指導(dǎo)和支持。

原文標(biāo)題:如何為我們的應(yīng)用程序提供一個(gè)更小、更快的視頻通話庫

文章出處:【微信公眾號(hào):LiveVideoStack】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

責(zé)任編輯:haq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 網(wǎng)絡(luò)
    +關(guān)注

    關(guān)注

    14

    文章

    8340

    瀏覽量

    95606
  • 視頻通話
    +關(guān)注

    關(guān)注

    0

    文章

    49

    瀏覽量

    12455

原文標(biāo)題:如何為我們的應(yīng)用程序提供一個(gè)更小、更快的視頻通話庫

文章出處:【微信號(hào):livevideostack,微信公眾號(hào):LiveVideoStack】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    運(yùn)行測(cè)試程序以讀取通過受信任應(yīng)用程序 (TA) 存儲(chǔ)的安全 blob 時(shí),內(nèi)存不足怎么解決?

    當(dāng)我運(yùn)行測(cè)試程序以讀取通過受信任應(yīng)用程序 (TA) 存儲(chǔ)的安全 blob 時(shí),我遇到了內(nèi)存不足 (OOM) 問題。 我仔細(xì)觀察了代碼,但沒有發(fā)現(xiàn)任何內(nèi)存漏洞。 測(cè)試程序讀取對(duì)稱密鑰,并通過 TA
    發(fā)表于 04-10 10:52

    如何在 i.MX RT1050 上實(shí)現(xiàn)兩個(gè)鏡像(引導(dǎo)加載程序應(yīng)用程序)的雙 HAB 身份驗(yàn)證?

    )。 目前,我的想法是實(shí)現(xiàn)個(gè)自定義身份驗(yàn)證機(jī)制在第二階段引導(dǎo)加載程序中。引導(dǎo)加載程序將: 讀取應(yīng)用程序映像頁腳(包含公鑰、SHA-256
    發(fā)表于 04-07 06:14

    RDMA設(shè)計(jì)56:如何設(shè)計(jì)基于RDMA的應(yīng)用程序

    ,為時(shí) 1s,并同時(shí)調(diào)用 ibv_poll_cq()函數(shù)輪詢完成隊(duì)列處理工作完成事務(wù)(Work Completion,WC),該函數(shù)將返回應(yīng)用程序可處理的完成隊(duì)列條目數(shù)量。根據(jù)該數(shù)量,對(duì)每一個(gè) WC
    發(fā)表于 04-05 09:54

    如何構(gòu)建藍(lán)牙應(yīng)用程序?

    應(yīng)用程序使用藍(lán)牙(blueZ)。 我已經(jīng)安裝了 gcc-riscv64-linux-gnu。 但是,沒有安裝 blueZ 標(biāo)頭和。 如何構(gòu)建我的藍(lán)牙應(yīng)用程序?
    發(fā)表于 04-01 07:31

    生產(chǎn)環(huán)境數(shù)據(jù)連接池耗盡的全流程排查與性能優(yōu)化實(shí)戰(zhàn)

    數(shù)據(jù)連接池是應(yīng)用程序與數(shù)據(jù)之間的緩存連接組件。連接池在應(yīng)用程序啟動(dòng)時(shí)創(chuàng)建組數(shù)據(jù)連接,
    的頭像 發(fā)表于 03-27 15:58 ?352次閱讀

    請(qǐng)問如何構(gòu)建和運(yùn)行視頻編解碼器示例應(yīng)用程序?

    如何構(gòu)建和運(yùn)行視頻編解碼器示例應(yīng)用程序?
    發(fā)表于 03-10 06:27

    何為 Vision Five 2 編譯自定義 Linux 內(nèi)核?

    些參考、幫助和鏈接,說明如何為 Vision Five 2 編譯自定義內(nèi)核以及 StarFive 開發(fā)團(tuán)隊(duì)必須提供哪些驅(qū)動(dòng)程序,那就太好了。
    發(fā)表于 02-24 07:44

    文詳解SystemC仿真的編譯

    AMD Vivado 設(shè)計(jì)套件以文件和的形式提供仿真模型。仿真包含器件和 IP 的行為和時(shí)序模型。編譯后的可供多個(gè)設(shè)計(jì)項(xiàng)目使用。用戶必須在設(shè)計(jì)仿真之前通過名為 compile_s
    的頭像 發(fā)表于 12-12 15:08 ?5097次閱讀
    <b class='flag-5'>一</b>文詳解SystemC仿真<b class='flag-5'>庫</b>的編譯

    與標(biāo)準(zhǔn)C的區(qū)別

    主要的差異: 1.代碼(數(shù)據(jù))量更小(對(duì)比上圖)。 2.缺少些不常用標(biāo)準(zhǔn)庫函數(shù),比如:文件 I/O 的庫函數(shù)。 3.微最大程度優(yōu)化代碼量,可能會(huì)導(dǎo)致有些代碼運(yùn)行速度更慢。 4.可
    發(fā)表于 12-09 07:49

    PYQT 應(yīng)用程序框架及開發(fā)工具

    特點(diǎn),已成為嵌入式領(lǐng)域的重要開發(fā)工具 PyQt 是個(gè)創(chuàng)建 GUI 應(yīng)用程序的工具包。它是 Python 編程語言和 Qt 的成功融合。因?yàn)榭捎玫念愑泻芏?,他們被分成幾個(gè)模塊。Qt
    發(fā)表于 10-29 07:15

    如何在應(yīng)用程序調(diào)試期間分析棧和堆使用情況

    隨著 AMD Vitis 統(tǒng)軟件平臺(tái) 2021.2 的發(fā)布,Vitis 引入了個(gè) Tcl 腳本,用于在應(yīng)用程序運(yùn)行的特定時(shí)間點(diǎn)協(xié)助查找棧和堆的內(nèi)存使用情況。該腳本已延續(xù)到后續(xù)的 V
    的頭像 發(fā)表于 10-24 16:54 ?1072次閱讀
    如何在<b class='flag-5'>應(yīng)用程序</b>調(diào)試期間分析棧和堆使用情況

    學(xué)生適合使用的SOLIDWORKS 云應(yīng)用程序

    隨著科技的不斷發(fā)展,計(jì)算機(jī)輔助設(shè)計(jì)(CAD)技術(shù)已經(jīng)成為現(xiàn)代工程教育的重要組成部分。SOLIDWORKS作為款CAD軟件,其教育版云應(yīng)用程序為學(xué)生提供了強(qiáng)大而靈活的設(shè)計(jì)平臺(tái)。本文將探討
    的頭像 發(fā)表于 09-15 10:39 ?968次閱讀
    學(xué)生適合使用的SOLIDWORKS 云<b class='flag-5'>應(yīng)用程序</b>

    FX3 UVC 無法與 Ubuntu 24.04 Cheese 或 Snapshot 相機(jī)應(yīng)用程序配合使用,怎么處理?

    添加了來自 VLC 的日志以供比較。根據(jù)日志,似乎 PipeWire 或 UVC 驅(qū)動(dòng)程序存在些問題。 我直在做些調(diào)試,發(fā)現(xiàn)對(duì)于 Ubuntu
    發(fā)表于 07-16 06:37

    使用 USB CDC 下載應(yīng)用程序固件,用時(shí)過長(zhǎng)是為什么?

    我已經(jīng)在PSoC? 6 WIFI-BT Pioneer Kit 上嘗試了 DFU 示例代碼,發(fā)現(xiàn)了件奇怪的事情。 如果我使用 UART-over-USB 下載應(yīng)用程序固件,則只需 20 秒。但是
    發(fā)表于 07-14 07:10

    華秋DFM軟件升級(jí)時(shí),提示“應(yīng)用程序無法正常啟動(dòng)”怎么辦?

    ;關(guān)閉應(yīng)用程序?!?,如下圖所示: 出現(xiàn)該問題的原因: 系統(tǒng)缺少對(duì)應(yīng)的運(yùn)行時(shí),DFM安裝包提供的運(yùn)行庫版本又和系統(tǒng)不兼容 對(duì)應(yīng)解決方案: 安裝微軟提供的運(yùn)行時(shí)
    發(fā)表于 06-12 18:32
    汽车| 侯马市| 高陵县| 延安市| 沂源县| 重庆市| 淳化县| 同心县| 横山县| 吉水县| 武邑县| 台前县| 杂多县| 东光县| 清新县| 榆树市| 塔城市| 湘乡市| 墨江| 锡林郭勒盟| 来凤县| 昌宁县| 上思县| 历史| 海晏县| 永德县| 田东县| 泰安市| 亚东县| 黄大仙区| 辽阳市| 尼勒克县| 舞阳县| 昌平区| 郸城县| 正蓝旗| 洛隆县| 昭平县| 静海县| 城口县| 峨边|