成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

淺談RSocket與響應式編程

開發 開發工具
首先,RSocket是高效一個二進制的網絡通訊協議,能夠滿足很多場景下使用。其次,RSocket是一個激進的響應式捍衛者,激進到連API都跟響應式無縫集成。

 一 RSocket的主要特性

首先,RSocket是高效一個二進制的網絡通訊協議,能夠滿足很多場景下使用。其次,RSocket是一個激進的響應式捍衛者,激進到連API都跟響應式無縫集成。

1 四種通訊模式

即發即忘FireAndForget

立即發送一個請求,無需為這個請求發送響應報文。適用于監控埋點,日志上報等,這種場景下無需回執,丟失幾個請求無傷大雅。

??

??

 

請求響應RequestResponse

請求方發送一條請求消息,響應方收到請求后并返回一條響應消息。傳統的HTTP是典型的RequestResponse。

??

??

 

流RequestStream

請求方發送一個請求報文,響應方發回N個響應報文。傳統的MQ是典型的RequestStream。

??

??

 

通道RequestChannel

創建一個通道上下文,雙方可以互相發送消息。IM是個典型的RequestChannel通訊場景。

??

??

 

2 雙向通訊Bi-Directional

RSocket的Client連接到Server,這個過程稱為Setup,在連接成功后,會約定收發消息的方向邏輯:

  • 當Client請求Server時,發送的請求ID永遠為奇數
  • 當Server請求Client時,發送的請求ID永遠為偶數

??

??

 

正是因為這個奇偶性確定方向的特性,不同于傳統的如HTTP請求,RSocket可以做到雙向請求。

3 其他

  • 二進制協議,緊湊高效
  • 多路復用
  • 基于幀(Frame)的背壓,與ReactiveStreams語義契合
  • 靈活的傳輸層切換: TCP/UDP/WebSocket等
  • 支持Cancel、斷點續傳、租約等高級特性

綜上與HTTP做一些比較,RSocket的效率更高,支持的通訊場景更豐富,也沒有隊頭阻塞的問題。與SocketIO這種基于純事件的框架相比,RSocket的請求具有很清晰的上下文,API精煉易用。

??

??

 

二 RSocket的內部實現

1 幀的設計

幀(Frame)是RSocket協議報文的最小單位。

  • 一個幀由6 bytes的Header和剩余的Body構成,其中Header的4 bytes表示 StreamID,6 bits表示Frame Type, 10 bits作為Flags。Body根據不同的幀類型,結構也不同,常用的帶Payload的幀一般會包括Metadata和Data兩個部分。
  • 傳輸層如果本身不支持分幀特性的(如TCP),那么RSocket會用3 bytes的uint24表示幀長度,所以最大的幀大小是16MB。
  • 如果幀超出16MB,RSocket支持幀分裂重組,也就是拆成更小的幀,接收端再自動重組。

??

??

 

2 數據載體——Payload

基于幀之上,一般開發者接觸到的是Payload, 它類似一個HTTP報文,可以是一個Request,也可以是一個Response。由兩個二進制部分組成:

  • Metadata——元數據,類似HTTP的header
  • Data——數據,類似HTTP的body

??

??

 

3 架構

這里基于筆者在實現Golang版SDK的基礎上整理的架構圖,Java版基本也類似。

??

??

 

  • Transport層將網絡二進制流編解碼為Frames。
  • RSocket支持自定義最大Frame Size,默認16MB,當某個Frame超出時,會被拆解為N個小Frame,收到時再重組,在介紹幀的時候也提到了,這個特性稱為Fragmentation。
  • DuplexConnection轉換Frames為Payload,抽象為一個個Request/Response上下文,并負責讀寫。
  • RSocket組裝Connection為RSocket Interface,其中Resumable支持斷點續傳,連接斷開重連也能自愈,個人覺得這個特性有點雞肋,在弱網環境有些優勢,但是因為期間會緩存住未處理完畢的幀,所以會耗費大量的系統資源。
  • RSocket使用Reactor核心庫暴露為4種通訊模式,抽象為高級API。

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,非常精煉。

  • Publisher:發布者,負責生產數據。唯一的方法subscribe,接收一個Subscriber開始一次新的訂閱。
  • Subscriber:訂閱者,負責訂閱消費數據。
  • Subscription:訂閱,某次訂閱的上下文控制,如取消、通知獲取下N條數據。

Spring的Reactor是一個標準的實現,其一次完整的執行過程如下圖:

??

??

 

  • 創建subscriber,開始訂閱Publisher。
  • 生成上下文subscription。
  • Publisher就緒,調用onSubscribe。
  • Publisher開始生產數據。
  • 每條成功生產的數據回調onNext。
  • 當生產失敗時,回調onError并結束當前訂閱。
  • 當所有數據生產完畢時,回調onComplete并結束當前訂閱。
  • 中途可以調用subscription隨時cancel取消訂閱,或者通過request(n)通知生產下N個元素,這個過程即背壓。

由于Java天生的語言優勢,很適合使用RxJava或Reactor之類的框架,代碼邏輯清晰可讀性會非常高。筆者在實現Go版的Reactor時,深深地體會到了沒有泛型支持的API表現力是多么匱乏,也期待Go2的泛型能夠有所改善。

四 總結

RSocket是個很有趣的網絡協議,它可能不會普及流行,但貴在它解決問題的思路和設計很令人耳目一新。如果大家有興趣,可以去它的官網了解下。

本文總結了筆者在實現Go和Rust版RSocket SDK過程中的一些心得感悟,有興趣的同學可查看相關鏈接。

 

責任編輯:武曉燕 來源: 51CTO專欄
相關推薦

2022-03-09 23:02:30

Java編程處理模型

2025-05-06 01:14:00

系統編程響應式

2011-06-09 09:52:41

F#

2022-06-16 13:08:30

Combine響應式編程訂閱

2022-07-15 08:16:56

Stream函數式編程

2009-07-17 10:37:05

C#多線程

2016-11-23 13:46:08

Android

2013-03-01 10:42:21

響應式Web

2011-10-14 09:23:14

2020-08-31 07:19:57

MonoFlux Reactor

2021-07-28 20:13:04

響應式編程

2023-07-12 08:16:54

JVM工具包Vert.x

2022-10-25 08:05:12

Kotlin響應式編程

2022-08-25 11:00:19

編程系統

2009-07-20 09:53:43

Java混合編程

2025-05-09 08:34:57

RSocketSpringBoot聊天系統

2022-09-01 08:00:00

響應式編程集成

2025-04-21 04:00:00

2016-05-18 10:20:15

GitHubswiftReactiveCoc

2020-10-27 10:26:03

編程開發Java
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲免费网 | 成人综合伊人 | 网站国产| 久久久精品国产 | 狠狠狠色丁香婷婷综合久久五月 | 国产免费一区二区三区 | 国产精品jizz在线观看老狼 | 中文字幕久久久 | 国产成人免费视频 | 国产毛片毛片 | 成人免费网站视频 | 欧美综合在线视频 | 日韩欧美在线观看 | 欧美三区在线观看 | 成人久久18免费网站 | 欧美亚洲在线 | 99中文字幕 | 夏同学福利网 | 色偷偷噜噜噜亚洲男人 | 国产成人免费网站 | 一级黄色片日本 | 亚洲一区 中文字幕 | 婷婷久久五月 | 亚洲一区二区三区四区五区午夜 | 天天拍天天操 | 不卡一区二区三区四区 | 久久久视频在线 | 999免费网站 | 作爱视频免费观看 | 中文字幕在线视频精品 | 中文字幕一区在线观看视频 | 欧美另类视频在线 | 高清一区二区 | 成人亚洲性情网站www在线观看 | 日韩一区二区三区av | 久久在线视频 | 日本综合在线观看 | 丁香久久 | 天天看天天操 | 精品美女久久久 | 黄色在线免费观看视频网站 |