音視頻領(lǐng)域的新技術(shù)應(yīng)用非常多,但是在工業(yè)和IoT領(lǐng)域,新技術(shù)的應(yīng)用卻鮮有耳聞。本次上海站大會我們邀請到了熹樂科技YoMo框架負(fù)責(zé)人——洪小堅,為我們分享熹樂科技和YoMo會為工業(yè)和IoT帶來哪些新鮮血液。
大家好,今天分享的主題是可編程的流式計算框架。大家可能都比較關(guān)心音視頻領(lǐng)域,我們YoMo面對的場景比較偏向工業(yè)、IoT等領(lǐng)域。雖然是不同的場景,但是仍然有很多技術(shù)的共同點。大家聽完以后會有不少收獲。
今天的大綱分為自我介紹、YoMo項目背景、YoMo典型用例、YoMo技術(shù)亮點、對邊緣計算的理解以及總結(jié)。
關(guān)于我和熹樂科技
01
首先做一個自我介紹。
我是從2007年開始做技術(shù)研發(fā),做了12年歐洲用戶的電商平臺。因為對邊緣計算和工業(yè)互聯(lián)網(wǎng)都很感興趣,所以2019年加入了現(xiàn)在的創(chuàng)業(yè)公司——熹樂科技。目前我正在維護(hù)今天的主角——YoMo項目。
熹樂科技很多朋友都是第一次聽到,下面做一個簡單的介紹。熹樂科技專注于工業(yè)互聯(lián)網(wǎng)和邊緣計算,打造了YoMo開源計算框架和YCloud云服務(wù)。我們從2015年開始將人工智能技術(shù)應(yīng)用于工業(yè)制造領(lǐng)域,例如計算機(jī)視覺對于地板的質(zhì)量檢測。熹樂科技目前持續(xù)服務(wù)了40余家工業(yè)企業(yè)。在2019年與“中國輕工集團(tuán)”共同成立了“中輕工互聯(lián)網(wǎng)有限公司”,主要是將邊緣計算等工業(yè)互聯(lián)網(wǎng)技術(shù)在輕工行業(yè)落地。
YoMo項目背景
02
下面介紹YoMo的項目背景以及設(shè)計的原理。
首先要介紹的是開放性。隨著網(wǎng)絡(luò)的基本設(shè)施,例如5G的普及,想要實現(xiàn)低時延看起來還是唾手可得的。5年以后,企業(yè)之間比拼的可能就是QUIC協(xié)議這種具有開放性的、基于User Space的可以作一些靈活擁塞控制的算法。未來的軟硬件可能都是可編程的、開放性的。
回過頭看看目前業(yè)內(nèi)一些主流的技術(shù),說到實時流式計算就會聯(lián)想到像Flink這種、消息隊列會想到Kafka。甚至我們微服務(wù)部署很多人會想到Docker,但這些技術(shù)其實都是幾年前開始設(shè)計的,都屬于消費者互聯(lián)網(wǎng)。未來會進(jìn)入IoT的時代,之前的技術(shù)雖然現(xiàn)在還是主流,但是不一定會適合未來。我們在做產(chǎn)品的時候就想通過新的技術(shù),來創(chuàng)造一些新的機(jī)會。
近幾年新聞報道了很多工業(yè)的事故,造成了巨大的人員傷亡和經(jīng)濟(jì)損失。加之現(xiàn)在國家政策一直在鼓勵安全生產(chǎn),所以我們的客戶就想做安全生產(chǎn),例如數(shù)字化檢測和預(yù)警系統(tǒng)等。“中輕工互聯(lián)網(wǎng)”去年就服務(wù)了一家化工企業(yè)。
安全生產(chǎn)的最高等級就是實現(xiàn)本質(zhì)安全的理論。本質(zhì)安全就是不論是設(shè)備故障還是人為操作不當(dāng),都可以提前預(yù)測事故的發(fā)生。要做到本質(zhì)安全,就需要做到計算連續(xù)3s的數(shù)據(jù)變化趨勢。同時AI算法會對不久將來可能發(fā)生的事故做出反應(yīng)。例如未來30s后可能會爆炸,這時就需要提前向化學(xué)反應(yīng)堆里加阻燃劑。
要做到這樣的操作,還需要在1s內(nèi)做到30次的計算,一次大約為33ms。如果這個計算節(jié)點部署在云計算中心,那么光數(shù)據(jù)的傳輸可能就已經(jīng)超過該時限了。上面提到的33ms不僅僅包括數(shù)據(jù)傳輸,還要包括AI計算的時間。因此想要做到本質(zhì)安全,就需要對傳感器的數(shù)據(jù)進(jìn)行實時的采集和計算。
要做到實時采集就需要低時延的傳輸,一是利用類似QUIC的協(xié)議,二是隨著5G、WiFi6的普及,對保障低時延傳輸有很大的幫助。另外,我們需要對采集到數(shù)據(jù)進(jìn)行毫秒級的計算,這就需要在邊緣端部署才能實現(xiàn)。如果部署在云端,即便計算速度很快,但因為傳輸速度的不足也會導(dǎo)致毫秒級計算無法實現(xiàn)。除了以上兩點,還需要在邊緣端部署一個Edge AI進(jìn)行全維度的計算來實現(xiàn)預(yù)緊預(yù)測。
根據(jù)現(xiàn)在的趨勢,將來實時計算比例會越來越高,IDC預(yù)測2025年實時數(shù)據(jù)計算將會占比30%。
這是目前IoT領(lǐng)域的一些主流協(xié)議。TCP是1983年誕生,距離現(xiàn)在已經(jīng)快40年。另一個主流的MQTT協(xié)議也已經(jīng)誕生20多年。隨著5G的普及,這些老舊技術(shù)就像在動車鐵軌上跑的綠皮火車。Google在2012年就提出QUIC協(xié)議,在2016年進(jìn)行 IETF的國際標(biāo)準(zhǔn)化。但是因為極大的升級成本,所以目前在工業(yè)領(lǐng)域目前用QUIC的并不是很多,但是在音視頻領(lǐng)域國內(nèi)外用應(yīng)用的卻很多。熹樂的目標(biāo)就是將QUIC技術(shù)方便的應(yīng)用到工業(yè)領(lǐng)域。
我們提出gRPC for IoT的理念。gRPC是一個很主流的微服務(wù)RPC框架。gRPC for IoT就是希望在邊緣端可以實現(xiàn)全鏈路的QUIC Transport。例如Client/Server服務(wù)可以通過QUIC建連從而變成P2P的模式。傳統(tǒng)Client/Server的問題在于只有在Client請求以后Server才會響應(yīng),這種模式是單向的。而用QUIC建連之后,就是雙向連接Peer to Peer,同時又是長鏈接。為什么是長鏈接?因為IoT設(shè)備數(shù)據(jù)是24小時不間斷的,如果每次請求都斷開、重新建連會造成時延的影響。
另外我們針對IoT領(lǐng)域推出自研的Codec。熹樂科技在IoT領(lǐng)域很重視網(wǎng)絡(luò)傳輸編解碼的效率方面。IoT數(shù)據(jù)的實時采集并通過長鏈接發(fā)送的模式和視頻直播是很相像的。
IoT的設(shè)備到2025年將達(dá)到750億。這意味將有越來越多的設(shè)備需要進(jìn)行數(shù)據(jù)采集,由此產(chǎn)生的APP應(yīng)用也會越來越多。
現(xiàn)在市場對APP的開發(fā)要求越來越快,time to market越快越好,現(xiàn)在很多低代碼、無代碼就是為了縮短開發(fā)時間。YoMo框架十分重視開發(fā)者友好,以便開發(fā)者使用時可以節(jié)省時間。
為了節(jié)省開發(fā)時間我們提出了Streaming Serverless的概念。Serverless的優(yōu)勢在于只需要專注幾行核心代碼、無需關(guān)心 DevOps、自動彈性伸縮,以及按需計費,低成本。IoT領(lǐng)域的數(shù)據(jù)是24小時不間斷產(chǎn)生的、沒有邊界,是典型的streaming場景,雖然現(xiàn)在已經(jīng)有很多比較成熟的Serverless框架,但市面上大多數(shù) Serverless 框架是面向傳統(tǒng)的HTTP Request/Response 模式。因此我們針對該場景提出了Streaming Serverless。
這是一條比較有意思的推特。這個推特是Docker的創(chuàng)始人在2019年提出來的,他在推特中提到,如果2008年出現(xiàn)WebAssembly,那么他們都沒有必要去創(chuàng)建Docker了。WebAssembly之前跑在瀏覽器端比較多,現(xiàn)在的趨勢卻是跑在服務(wù)端。
WebAssembly和Docker相比具有哪些優(yōu)勢呢?WebAssembly的Cold Start會比Docker快100倍。其次前者執(zhí)行時間較后者也快10%-50%。另外WebAssembly 占用的空間更小。最后WebAssembly有更靈活的安全策略,可以根據(jù)不同模塊,在實例化時指定不同權(quán)限。
因為在邊緣節(jié)點資源會比較受限,所以WebAssembly綜合了輕量級、更優(yōu)的性能、更高的安全性和多語言的特點。多語言對于Serverless尤其重要,因為現(xiàn)在很多主流的開發(fā)語言都支持把程序編譯成WebAssembly,具有這樣的特點會有很多的好處。
綜合上述的方方面面,我們做了YoMo開源框架。
YoMo應(yīng)用案例
03
再來分享幾個典型的案例。
我們在辦公室部署了一個實時噪聲傳感器,來測試YoMo框架是否能達(dá)到低時延。因為MQTT協(xié)議需要安裝MQTT Broker,所以我們在數(shù)據(jù)采集端做了一個MQTT兼容的API,這樣可以減少用戶的負(fù)擔(dān),無需安裝 MQTT Broker 即可接入 YoMo。為了測試實驗,我們將Serverless的節(jié)點部署在寧夏的AWS,來測量北京到寧夏,再從寧夏返回北京的時延。
我們的測試結(jié)果顯示時延基本能穩(wěn)定在30ms以內(nèi)。另外像屏幕上顯示的分貝值,傳統(tǒng)的做法是把傳感器數(shù)據(jù)先保存到數(shù)據(jù)庫,然后再進(jìn)行查詢顯示,這樣就會造成時延的損失,所以YoMo采取通過WebSocket直接顯示到屏幕上。同時用另外一個 Serverless服務(wù)把數(shù)據(jù)落地到 DB。
白酒智能釀造平臺是一個工業(yè)級的應(yīng)用。白酒行業(yè)的一大特點是很多釀酒工藝是通過老師傅的經(jīng)驗傳授,這樣是非常主觀的。我們在和一個研究白酒幾十年的專業(yè)研究院——中國食品發(fā)酵工業(yè)研究院合作后,獲得了他們提供的硬件和相關(guān)的工業(yè)算法。接著我們對這些設(shè)備進(jìn)行了實時的工藝采集和計算,把老師傅的經(jīng)驗數(shù)字化,從而獲得穩(wěn)定的工藝,提高了出酒率和效率。
海外有一個用戶想做用戶行為的跟蹤,分析一些網(wǎng)站上用戶什么樣的行為會導(dǎo)致轉(zhuǎn)換率的降低等問題。針對這樣的場景,我們做了Geo-Distributed的分布式解決方案,將傳統(tǒng)的中心化架構(gòu)拆分成多個靠近用戶的邊緣節(jié)點。
最后一個案例是分布式的爬蟲。我們服務(wù)了一個海外提供物流查詢的SaaS公司。之前這個公司的查詢都是通過 proxy去獲取,這樣會造成很高的時延,同時穩(wěn)定性也不高,更加嚴(yán)重的是數(shù)據(jù)隱私可能泄露。通過YoMo框架,我們在更靠近快遞公司的節(jié)點部署了一個爬蟲服務(wù),通過QUIC協(xié)議,把請求通過長連接返回給美國的用戶。這些服務(wù)器都是部署在用戶自己的機(jī)器上,數(shù)據(jù)隱私得以保障,也節(jié)省了proxy代理的開支。
YoMo features
04
通過之前的講座,在座的嘉賓多少對QUIC協(xié)議有一定的了解,這些內(nèi)容就快速通過。
QUIC優(yōu)點是非常多的。最好的就是最下面的兩點。一個是User space,我在開頭開放性那里也提到過User space,可以更方便的進(jìn)行軟件升級。TCP內(nèi)核態(tài)的升級就沒有那么方便。二是擁塞控制算法。根據(jù)不同的場景進(jìn)行靈活的控制,具有更高的可編程性。
QUIC在業(yè)內(nèi)的應(yīng)用實踐音視頻方面比較多。國內(nèi)很多的大廠在兩三年前就開始研究音視頻方面的應(yīng)用。QUIC對性能的提升幫助很大,包括卡頓率等等。因為看好QUIC 的前景,加之工業(yè)領(lǐng)域應(yīng)用很少,所以我們想推動QUIC在工業(yè)、IoT領(lǐng)域的運用。
這里視頻借用了阿里手機(jī)淘寶的視頻,左邊采用多通道的QUIC,右邊沒有采用。如果WiFi出現(xiàn)抖動的,左邊可以通過蜂窩網(wǎng)絡(luò)流暢運行,而右邊只用到 WiFi 就出現(xiàn)卡頓的情況。
自研的 Y3 Codec我們稱它為faster than real-time。如果是傳統(tǒng)的JSON的話,就需要拿到完整數(shù)據(jù)以后進(jìn)行解碼。針對IoT,例如之前提到的噪聲,只要獲取噪聲分貝的字段即可。對此,我們使用了TLV的結(jié)構(gòu)。結(jié)構(gòu)里的Tag相當(dāng)于 JSON的key。通過監(jiān)聽Tag是不是用戶關(guān)心的,如果是就直接獲取,不是則skip,再根據(jù)Length判斷需要skip多少字節(jié)。
性能測試中Y3 Codec相比JSON提升超10倍以上,與Protobuf相比也有明顯的提升。下表所展示的是一些性能報告。
響應(yīng)式的編程用excel的應(yīng)用來形象的說明。假設(shè)a=b+c,那么對b、c進(jìn)行修改a也會有動態(tài)的響應(yīng),這種模式是十分適合數(shù)據(jù)隨著時間變化的場景。
ReactiveX也針對異步數(shù)據(jù)提供了一個良好的編程模型。ReactiveX最早是由微軟提出。在操作異步數(shù)據(jù)時可以使用一些通用的方法,就會像操作同步數(shù)據(jù)一樣方便,只要組合幾個常用的函數(shù)就可以操作異步數(shù)據(jù)流。
假設(shè)每30ms都會傳遞一次數(shù)據(jù),可實際場景可能是連續(xù)兩個30ms都沒有數(shù)據(jù),第三個30ms突然出現(xiàn)三個數(shù)據(jù)。針對這種場景我們實際只要獲取最新的數(shù)據(jù)即可。使用 Rx 可以簡化這個問題,使用 debounce 即可獲取每 30ms 內(nèi)的最新一條數(shù)據(jù)。
Streaming Serverless讓用戶不需要操作QUIC Stream,只需要操作Rx Stream。可以根據(jù)業(yè)務(wù)需求進(jìn)行Operator方法的組合即可。另外市面上很多Serverless服務(wù)在本地調(diào)試比較麻煩,所以YoMo支持CLI的方式本地運行和調(diào)試。
邊緣計算
05
邊緣計算各位多多少少也有一定了解
整個行業(yè)的趨勢是從之前的大型機(jī)通過終端連接變成PC端去中心化場景。發(fā)展到移動互聯(lián)時代又回到了中心化的云計算中心。到IoT時代因為數(shù)據(jù)量的巨大,需要邊緣端進(jìn)行分布式來緩解云計算中心的壓力。邊緣計算雖然越來越重要,但是邊緣計算并不會取代云計算,他們會共同存在。
邊緣計算的優(yōu)勢一是降低傳輸距離。二是就近計算更快的響應(yīng)。第三,比較重要,邊緣計算可以保護(hù)安全隱私。很多工業(yè)企業(yè)并不是很愿意把數(shù)據(jù)傳輸?shù)焦性品?wù)上,所以隱私保護(hù)顯得格外重要。最后一點就是低成本。邊緣計算可以減少帶寬傳遞的成本。
云計算和邊緣計算的對比發(fā)現(xiàn),云計算的性能更強(qiáng)但時延、帶寬成本較高,邊緣計算恰恰相反。云計算和邊緣計算在使用上互補(bǔ),以滿足不同場景的使用需求。
對此我們做了Geo-Distributed Edge Cloud。用戶可以根據(jù)時延需求來部署在不同的地方。低時延可以部署在城市級節(jié)點。如果有數(shù)據(jù)監(jiān)管要求則可以部署在私有云。另外部署在云計算中心也是可以實現(xiàn)的。
總結(jié)
06
最后對今天的匯報進(jìn)行一個總結(jié)。
YoMo的項目背景是面向未來可編程的開放性。針對網(wǎng)絡(luò)傳輸提出gRPC for IoT——全鏈路采用QUIC以及Y3 Codec 高性能編解碼。另外為了加快用戶開發(fā)APP的速度,提出了Streaming Serverless的框架。針對YoMo的使用場景,運行在WebAssembly會比Docker更加具有優(yōu)勢。最后邊緣計算方面YoMo可以基于Geo-Distributed Cloud進(jìn)行就近部署。
以上就是YoMo的開源計劃,希望對YoMo感興趣的朋友們可以多多關(guān)注。
謝謝大家!
編輯:jq
-
IDC
+關(guān)注
關(guān)注
4文章
393瀏覽量
37276 -
云計算中心
+關(guān)注
關(guān)注
0文章
10瀏覽量
7332 -
5G
+關(guān)注
關(guān)注
1356文章
48503瀏覽量
565508 -
IOT
+關(guān)注
關(guān)注
187文章
4230瀏覽量
197353 -
邊緣計算
+關(guān)注
關(guān)注
22文章
3121瀏覽量
49332
原文標(biāo)題:可編程的流式計算框架:YoMo
文章出處:【微信號:livevideostack,微信公眾號:LiveVideoStack】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
評論