Reactive Programming入門概念詳解
正文
為了應(yīng)對高并發(fā)環(huán)境下的服務(wù)端編程,xx提出了一個實現(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é)議將描述必要的操作和實體,從而實現(xiàn)具有非阻塞背壓的異步數(shù)據(jù)流。
Reactive Streams API
中如下四個接口:(后面文章詳細(xì))
- Publisher 發(fā)布者(生產(chǎn)者)
public interface Publisher<T> { public void subscribe(Subscriber<? super T> s); }
- Subscriber訂閱者(消費者)
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)式編程框架,實現(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ǔ),實現(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)文章
idea2019版與maven3.6.2版本不兼容的解決方法
這篇文章主要介紹了idea2019版與maven3.6.2版本不兼容的解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10SpringBoot整合EasyCaptcha實現(xiàn)圖形驗證碼功能
這篇文章主要介紹了SpringBoot整合EasyCaptcha實現(xiàn)圖形驗證碼功能,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2024-02-02解決idea出現(xiàn)的java.lang.OutOfMemoryError:?Java?heap?space的問題
我們在使用idea的時候經(jīng)常會遇到一些問題,本文介紹了如何解決idea出現(xiàn)的java.lang.OutOfMemoryError:?Java?heap?space的問題,文中有相關(guān)的圖文示例,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06Java8內(nèi)存模型PermGen Metaspace實例解析
這篇文章主要介紹了Java8內(nèi)存模型PermGen Metaspace實例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-03-03Spring框架中ImportBeanDefinitionRegistrar的應(yīng)用詳解
這篇文章主要介紹了Spring框架中ImportBeanDefinitionRegistrar的應(yīng)用詳解,如果實現(xiàn)了ImportSelector接口,在配置類中被@Import加入到Spring容器中以后,Spring容器就會把ImportSelector接口方法返回的字符串?dāng)?shù)組中的類new出來對象然后放到工廠中去,需要的朋友可以參考下2024-01-01