Reactive Programming入門概念詳解
正文
為了應(yīng)對高并發(fā)環(huán)境下的服務(wù)端編程,xx提出了一個實(shí)現(xiàn)異步編程的方案 -Reactive Programming,中文名稱反應(yīng)式編程。反應(yīng)式編程(reactive programming)并不是一個新的概念,也不是一個新的技術(shù),很早之前就被提出來了。
先從幾個概念入門說起:
- Reactive Programming
- Reactive Streams
- Reactor
- Webflux
Reactive Programming
反應(yīng)式編程 (reactive programming) 是一種基于數(shù)據(jù)流 (data stream) 和 變化傳遞 (propagation of change) 的聲明式 (declarative) 的編程范式。
響應(yīng)式編程使用三個核心概念:數(shù)據(jù)流,變化傳遞和異步觀察。
換句話說:使用異步數(shù)據(jù)流進(jìn)行編程,這意味著可以在編程語言中很方便地表達(dá)靜態(tài)或動態(tài)的數(shù)據(jù)流,而相關(guān)的計算模型會自動將變化的值通過數(shù)據(jù)流進(jìn)行傳播。反應(yīng)式編程提高了代碼的抽象級別,可以只關(guān)注定義了業(yè)務(wù)邏輯的那些相互依賴的事件。
Reactive Streams
Reactive Streams :The purpose of Reactive Streams is to provide a standard for asynchronous stream processing with non-blocking backpressure。
Reactive Streams 的目的是為具有非阻塞背壓的異步流處理提供標(biāo)準(zhǔn)。
對于Java程序員,Reactive Streams是一個API。Reactive Streams為我們提供了Java中的Reactive Programming的通用API。
Reactive Streams API的范圍是找到一組最小的接口,方法和協(xié)議,這些接口,方法和協(xié)議將描述必要的操作和實(shí)體,從而實(shí)現(xiàn)具有非阻塞背壓的異步數(shù)據(jù)流。
Reactive Streams API中如下四個接口:(后面文章詳細(xì))
- Publisher 發(fā)布者(生產(chǎn)者)
public interface Publisher<T> {
public void subscribe(Subscriber<? super T> s);
}
- Subscriber訂閱者(消費(fèi)者)
public interface Subscriber<T> {
public void onSubscribe(Subscription s);
public void onNext(T t);
public void onError(Throwable t);
public void onComplete();
}
- Subscription 訂閱
public interface Subscription {
public void request(long n);
public void cancel();
}
- Processor 處理者
public interface Processor<T, R> extends Subscriber<T>, Publisher<R> {
}
Spring Reactor
Reactor 是第四代響應(yīng)式庫,基于Reactive Streams規(guī)范,用于在 JVM 上構(gòu)建非阻塞應(yīng)用程序。是Spring提供的非阻塞式響應(yīng)式編程框架,實(shí)現(xiàn)了Reactive Streams規(guī)范而已
- reactor-core: Reactor 完全無阻塞,并提供高效的管理,它直接與Java的函數(shù)式API,CompletableFuture,Stream配合使用
- [0|1| N]序列:Reactore提供了兩個響應(yīng)式和可組合的API,Flux 和 Mono。
Flux 表示的是包含 0 到 N 個元素的異步序列。在該序列中可以包含三種不同類型的消息通知:正常的包含元素的消息、序列結(jié)束的消息和序列出錯的消息。當(dāng)消息通知產(chǎn)生時,訂閱者中對應(yīng)的方法 onNext(), onComplete()和 onError()會被調(diào)用。Mono 表示的是包含 0 或者 1 個元素的異步序列。該序列中同樣可以包含與 Flux 相同的三種類型的消息通知。Flux 和 Mono 之間可以進(jìn)行轉(zhuǎn)換。對一個 Flux 序列進(jìn)行計數(shù)操作,得到的結(jié)果是一個 Mono對象。把兩個 Mono 序列合并在一起,得到的是一個 Flux 對象。
- Non-Blocking IO: Reactor 為HTTP(包括websocket),TCP和UDP提供背壓就緒的網(wǎng)絡(luò)引擎。
- webflux
Spring 產(chǎn)品組合提供了兩個并行堆棧。 一種是基于帶有 Spring MVC 和 Spring Data 結(jié)構(gòu)的 Servlet API。 另一個是完全反應(yīng)式堆棧,它利用了 Spring WebFlux 和 Spring Data 的反應(yīng)式存儲庫。 如下技術(shù)棧:Spring官方提供

數(shù)據(jù)庫:以一種反應(yīng)的方式訪問和處理數(shù)據(jù)是非常重要的。MongoDB、Redis和Cassandra都有原生的Spring數(shù)據(jù)響應(yīng)支持。許多關(guān)系數(shù)據(jù)庫(Postgres、Microsoft SQL Server、MySQL、H2和GoogleSpanner)通過R2DBC提供了反應(yīng)性支持。
在消息傳遞的世界中,Spring Cloud Stream還支持對RabbitMQ和Kafka等平臺的反應(yīng)性訪問。
Reactive Streams、Reactor和WebFlux 區(qū)別?
上面介紹了反應(yīng)式編程的一些概念。三者的關(guān)系:
- Reactive Streams 是一套反應(yīng)式編程標(biāo)準(zhǔn)和規(guī)范;
- Reactor 是基于 Reactive Streams 一套反應(yīng)式編程框架;
- WebFlux 以 Reactor 為基礎(chǔ),實(shí)現(xiàn) Web 領(lǐng)域的反應(yīng)式編程框架。
參考:
- Reactive Streams :github.com/reactive-st…
- jdk-reactive:www.reactive-streams.org/
- reactor官方地址: projectreactor.io/
以上就是Reactive Programming入門概念詳解的詳細(xì)內(nèi)容,更多關(guān)于Reactive Programming入門的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
SpringBoot詳解整合Spring?Boot?Admin實(shí)現(xiàn)監(jiān)控功能
這篇文章主要介紹了SpringBoot整合Spring?Boot?Admin實(shí)現(xiàn)服務(wù)監(jiān)控,內(nèi)容包括Server端服務(wù)開發(fā),Client端服務(wù)開發(fā)其中Spring?Boot?Admin還可以對其監(jiān)控的服務(wù)提供告警功能,如服務(wù)宕機(jī)時,可以及時以郵件方式通知運(yùn)維人員,感興趣的朋友跟隨小編一起看看吧2022-07-07
解決maven中只有Lifecycle而Dependencies和Plugins消失的問題
這篇文章主要介紹了maven中只有Lifecycle而Dependencies和Plugins消失的問題及解決方法,本文通過圖文的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2020-07-07
MyBatis參數(shù)處理實(shí)現(xiàn)方法匯總
這篇文章主要介紹了MyBatis參數(shù)處理實(shí)現(xiàn)方法匯總,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-08-08
Java操作Jenkins操作憑證(Credential)信息方式
這篇文章主要介紹了Java操作Jenkins操作憑證(Credential)信息方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-05-05
SpringBoot項(xiàng)目使用yml文件鏈接數(shù)據(jù)庫異常問題解決方案
在使用SpringBoot時,利用yml進(jìn)行數(shù)據(jù)庫連接配置需小心數(shù)據(jù)類型區(qū)分,如果用戶名或密碼是數(shù)字,必須用雙引號包裹以識別為字符串,避免連接錯誤,特殊字符密碼也應(yīng)用引號包裹2024-10-10
如何解決Mybatis-plus中@TableLogic注解失效問題
這篇文章主要介紹了如何解決Mybatis-plus中@TableLogic注解失效問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-05-05
使用IDEA對SpringBoot應(yīng)用進(jìn)行遠(yuǎn)程調(diào)試方式
文章介紹了如何在IDEA中對部署在服務(wù)器上的SpringBoot應(yīng)用進(jìn)行遠(yuǎn)程調(diào)試,通過配置遠(yuǎn)程調(diào)試端口和啟動參數(shù),本地IDEA可以設(shè)置斷點(diǎn)并進(jìn)行調(diào)試2025-02-02

