掃二維碼與項目經(jīng)理溝通
我們在微信上24小時期待你的聲音
解答本文疑問/技術(shù)咨詢/運營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流
首先,RSocket是高效一個二進制的網(wǎng)絡(luò)通訊協(xié)議,能夠滿足很多場景下使用。其次,RSocket是一個激進的響應(yīng)式捍衛(wèi)者,激進到連API都跟響應(yīng)式無縫集成。

創(chuàng)新互聯(lián)服務(wù)項目包括金牛網(wǎng)站建設(shè)、金牛網(wǎng)站制作、金牛網(wǎng)頁制作以及金牛網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,金牛網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到金牛省份的部分城市,未來相信會繼續(xù)擴大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
即發(fā)即忘FireAndForget
立即發(fā)送一個請求,無需為這個請求發(fā)送響應(yīng)報文。適用于監(jiān)控埋點,日志上報等,這種場景下無需回執(zhí),丟失幾個請求無傷大雅。
??
??
請求響應(yīng)RequestResponse
請求方發(fā)送一條請求消息,響應(yīng)方收到請求后并返回一條響應(yīng)消息。傳統(tǒng)的HTTP是典型的RequestResponse。
??
??
流RequestStream
請求方發(fā)送一個請求報文,響應(yīng)方發(fā)回N個響應(yīng)報文。傳統(tǒng)的MQ是典型的RequestStream。
??
??
通道RequestChannel
創(chuàng)建一個通道上下文,雙方可以互相發(fā)送消息。IM是個典型的RequestChannel通訊場景。
??
??
RSocket的Client連接到Server,這個過程稱為Setup,在連接成功后,會約定收發(fā)消息的方向邏輯:
??
??
正是因為這個奇偶性確定方向的特性,不同于傳統(tǒng)的如HTTP請求,RSocket可以做到雙向請求。
綜上與HTTP做一些比較,RSocket的效率更高,支持的通訊場景更豐富,也沒有隊頭阻塞的問題。與SocketIO這種基于純事件的框架相比,RSocket的請求具有很清晰的上下文,API精煉易用。
??
??
幀(Frame)是RSocket協(xié)議報文的最小單位。
??
??
基于幀之上,一般開發(fā)者接觸到的是Payload, 它類似一個HTTP報文,可以是一個Request,也可以是一個Response。由兩個二進制部分組成:
??
??
這里基于筆者在實現(xiàn)Golang版SDK的基礎(chǔ)上整理的架構(gòu)圖,Java版基本也類似。
??
??
RSocket有很多玩法,傳統(tǒng)的RPC自然不在話下,用來做IM也未嘗不可,某些特性也可以用來做代理或者網(wǎng)絡(luò)穿透。
IoT的場景,比如小明的家里有個智能空調(diào),小明想在外面通過手機APP來控制空調(diào)開關(guān),如何優(yōu)雅地描述這個控制問題?最精煉的解決方案就是"小明調(diào)用空調(diào)上開關(guān)的API"。
??
??
另外最經(jīng)典的玩法就是Broker了,Broker類似一種“軟路由”的方案,可以讓服務(wù)的發(fā)布訪問變得簡單。發(fā)布服務(wù)只要連接到Broker,調(diào)用方通過反向請求的方式來讓Broker透明轉(zhuǎn)發(fā)即可,摒棄了傳統(tǒng)的注冊中心,端口管理等常見的服務(wù)治理手段。
??
??
Broker有很多優(yōu)勢,發(fā)布服務(wù)不需要監(jiān)聽端口,無需Sidecar,服務(wù)注冊變得簡單,無需zk、etcd之類,LoadBalance變得簡單,也更安全,沒監(jiān)聽端口后很難攻擊。也有很多劣勢,網(wǎng)絡(luò)上多了一跳,性能是有一定損耗的,Broker是中心化設(shè)計,類似我們平時全局的Nginx一樣,但是Broker的優(yōu)雅啟停顯然更加復(fù)雜,受限于整個Broker集群的瓶頸等等。上帝為你關(guān)閉了一扇門,就一定會為你打開一扇窗。
目前高德落地的FaaS中大量使用了基于RSocket架構(gòu)的集團Broker,支撐了今年的五一長假,峰值QPS超20萬,平穩(wěn)零故障。
??
??
這里筆者也準備了一個教學(xué)用的Mini Broker,演示了兩個瀏覽器之間相互上下文調(diào)用彼此服務(wù)的場景,有興趣的同學(xué)可以查看。
??
??
響應(yīng)式編程是個老話題了,它早已無處不在,甚至你在Excel里SUM求和,本質(zhì)上也是種響應(yīng)式的思維。響應(yīng)式本質(zhì)上就是響應(yīng)變化的數(shù)據(jù)流。RSocket這個協(xié)議本身就是以響應(yīng)式之名,將其擴展到網(wǎng)絡(luò)層面。
??
??
而在我們平時工作中,必然會引入各種操作和變換:
??
??
JDK推出了響應(yīng)式標準API,撇開Processor之外,其核心接口就Publisher/Subscriber/Subscription,非常精煉。
Spring的Reactor是一個標準的實現(xiàn),其一次完整的執(zhí)行過程如下圖:
??
??
由于Java天生的語言優(yōu)勢,很適合使用RxJava或Reactor之類的框架,代碼邏輯清晰可讀性會非常高。筆者在實現(xiàn)Go版的Reactor時,深深地體會到了沒有泛型支持的API表現(xiàn)力是多么匱乏,也期待Go2的泛型能夠有所改善。
RSocket是個很有趣的網(wǎng)絡(luò)協(xié)議,它可能不會普及流行,但貴在它解決問題的思路和設(shè)計很令人耳目一新。如果大家有興趣,可以去它的官網(wǎng)了解下。
本文總結(jié)了筆者在實現(xiàn)Go和Rust版RSocket SDK過程中的一些心得感悟,有興趣的同學(xué)可查看相關(guān)鏈接。

我們在微信上24小時期待你的聲音
解答本文疑問/技術(shù)咨詢/運營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流