作者 | 素渡
來源 | 阿裏技術公眾號
一 RSocket的主要特性
首先,RSocket是高效一個二進制的網路通訊協定,能夠滿足很多場景下使用。其次,RSocket是一個激進的響應式捍衛者,激進到連API都跟響應式無縫整合。
1 四種通訊模式
即發即忘FireAndForget
立即發送一個請求,無需為這個請求發送響應報文。適用於監控埋點,日誌上報等,這種場景下無需回執,遺失幾個請求無傷大雅。
請求響應RequestResponse
請求方發送一條請求訊息,響應方收到請求後並返回一條響應訊息。傳統的HTTP是典型的RequestResponse。
流RequestStream
請求方發送一個請求報文,響應方發回N個響應報文。傳統的MQ是典型的RequestStream。
通道RequestChannel
建立一個通道上下文,雙方可以互相發送訊息。IM是個典型的RequestChannel通訊場景。
2 雙向通訊Bi-Directional
RSocket的Client連線到Server,這個過程稱為Setup,在連線成功後,會約定收發訊息的方向邏輯:
正是因為這個奇偶性確定方向的特性,不同於傳統的如HTTP請求,RSocket可以做到雙向請求。
3 其他
綜上與HTTP做一些比較,RSocket的效率更高,支持的通訊場景更豐富,也沒有隊頭阻塞的問題。與SocketIO這種基於純事件的框架相比,RSocket的請求具有很清晰的上下文,API精煉易用。
二 RSocket的內部實作
1 幀的設計
幀(Frame)是RSocket協定報文的最小單位。
2 數據載體——Payload
基於幀之上,一般開發者接觸到的是Payload, 它類似一個HTTP報文,可以是一個Request,也可以是一個Response。由兩個二進制部份組成:
3 架構
這瑞奇於筆者在實作Golang版SDK的基礎上整理的架構圖,Java版基本也類似。
4 玩法
RSocket有很多玩法,傳統的RPC自然不在話下,用來做IM也未嘗不可,某些特性也可以用來做代理或者網路穿透。
IoT的場景,比如小明的家裏有個智慧空調,小明想在外面透過手機APP來控制空調開關,如何優雅地描述這個控制問題?最精煉的解決方案就是"小明呼叫空調上開關的API"。
另外最經典的玩法就是Broker了,Broker類似一種「軟路由」的方案,可以讓服務的釋出存取變得簡單。釋出服務只要連線到Broker,呼叫方透過反向請求的方式來讓Broker透明轉發即可,摒棄了傳統的註冊中心,埠管理等常見的服務治理手段。
5 關於RSocket Broker
Broker有很多優勢,釋出服務不需要監聽埠,無需Sidecar,服務註冊變得簡單,無需zk、etcd之類,LoadBalance變得簡單,也更安全,沒監聽埠後很難攻擊。也有很多劣勢,網路上多了一跳,效能是有一定損耗的,Broker是中心化設計,類似我們平時全域的Nginx一樣,但是Broker的優雅啟停顯然更加復雜,受限於整個Broker集群的瓶頸等等。上帝為你關閉了一扇門,就一定會為你開啟一扇窗。
目前高德落地的FaaS中大量使用了基於RSocket架構的集團Broker,支撐了今年的五一長假,峰值QPS超20萬,平穩零故障。
這裏筆者也準備了一個教學用的Mini Broker,演示了兩個瀏覽器之間相互上下文呼叫彼此服務的場景,有興趣的同學可以檢視。
三 響應式編程
響應式編程是個老話題了,它早已無處不在,甚至你在Excel裏SUM求和,本質上也是種響應式的思維。響應式本質上就是響應變化的數據流。RSocket這個協定本身就是以響應式之名,將其擴充套件到網路層面。
1 響應式編程大概長這樣
而在我們平時工作中,必然會引入各種操作和變換:
2 Reactive Streams
JDK推出了響應式標準API,撇開Processor之外,其核心介面就Publisher/Subscriber/Subscription,非常精煉。
Spring的Reactor是一個標準的實作,其一次完整的執行過程如下圖:
由於Java天生的語言優勢,很適合使用RxJava或Reactor之類的框架,程式碼邏輯清晰可讀性會非常高。筆者在實作Go版的Reactor時,深深地體會到了沒有泛型支持的API表現力是多麽匱乏,也期待Go2的泛型能夠有所改善。
四 總結
RSocket是個很有趣的網路協定,它可能不會普及流行,但貴在它解決問題的思路和設計很令人耳目一新。如果大家有興趣,可以去它的官網了解下。
本文總結了筆者在實作Go和Rust版RSocket SDK過程中的一些心得感悟,有興趣的同學可檢視相關連結。
相關連結https:// github.com/jjeffcaii/rs ocket-minibroker
https:// github.com/rsocket/rsoc ket-go
https:// github.com/rsocket/rsoc ket-rust
技術公開課
【HaaS物聯網雲端一體低程式碼開發課程】
由阿裏雲IoT一線技術專家精心打磨,直擊當前物聯網領域學習痛點,由淺入深全方位介紹物聯網基礎知識和網路層基礎知識,幫助開發者建立物聯網感知層、傳輸層、平台層及套用層各層的功能概念,並深入學習如何使用HaaS進行端雲一體開發以及低程式碼開發新模式。
點選這裏,開始學習吧~
版權聲明: 本文內容由阿裏雲實名註冊使用者自發貢獻,版權歸原作者所有,阿裏雲開發者社群不擁有其著作權,亦不承擔相應法律責任。具體規則請檢視【阿裏雲開發者社群使用者服務協定】和【阿裏雲開發者社群智慧財產權保護指引】。如果您發現本社群中有涉嫌抄襲的內容,填寫侵權投訴表單進行舉報,一經查實,本社群將立刻刪除涉嫌侵權內容。