淺談Spring 5的響應式編程

来源:https://www.cnblogs.com/youruike-/archive/2020/02/04/12260132.html
-Advertisement-
Play Games

這篇使用Spring 5進行響應式編程的入門文章展示了你現在可以使用的一些新的non-blocking, asynchronous。感謝優銳課老師給予的指導! 近年來,由於響應式編程能夠以聲明性的方式(而不是強制性的)構建應用程式,從而在響應程式和彈性方面具有更強的響應能力,因此在開發人員社區和客戶 ...


這篇使用Spring 5進行響應式編程的入門文章展示了你現在可以使用的一些新的non-blocking, asynchronous。感謝優銳課老師給予的指導!

近年來,由於響應式編程能夠以聲明性的方式(而不是強制性的)構建應用程式,從而在響應程式和彈性方面具有更強的響應能力,因此在開發人員社區和客戶中日益流行。Spring 5將Reactive Systems納入其核心框架的事實表明,範式已向聲明式編程轉移。

響應式編程管理數據生產者與需要以非阻塞方式對數據做出反應的使用者之間的非同步數據流。因此,響應式編程全部與非同步和事件驅動的非阻塞應用程式有關,這些應用程式需要少量線程來擴展。

由於基於共用的可變狀態,線程和鎖擴展應用程式存在很高的複雜性,因此很難使用基於線程的框架來構建反應性應用程式。

在響應式編程上下文中,“一切都是流,並且當流中有數據時,一切都以非阻塞的方式進行。”

 

為什麼響應式編程

響應式編程的高度抽象性提高了代碼的可讀性,因此開發人員可以主要關註定義業務邏輯的事件的相互依賴性。

反應模式自然適合高度併發環境中的消息處理,這是企業常見的用例。

具有強制背壓的功能,響應式方法最適合控制生產者和消費者之間的流量,這將有助於避免記憶體不足的問題。

響應式編程可以更有效地管理高度互動和實時的應用程式或任何動作/事件可能觸發多個連接子系統的通知的情況。

 

實現響應式編程的理想用例

  • 大量交易處理服務,例如銀行業。
  • 大型線上購物應用程式(例如Amazon)的通知服務。
  • 股票交易同時變化的股票交易業務。

響應式流

“響應流”定義了一個API規範,該規範包含一組最少的介面,這些介面公開了用於定義具有非阻塞背壓的非同步數據流的操作和實體的方法。

引入反壓後,反應流允許訂戶控制發佈者的數據交換速率。

Reactive Streams API作為java.util.concurrent.Flow正式成為Java 9的一部分。

響應式流主要用作互操作性層。

 

Spring 5響應式編程產品

Spring-Web-Reactive模塊和Spring MVC都支持相同的@Controller編程,但是Spring-Web-Reactive另外在Reactive和非阻塞引擎上執行。

Spring-Web-Reactive模塊和Spring MVC共用許多常用演算法,但是Spring-Web-Reactive模塊已經重新定義了許多Spring MVC合約,例如HandlerMapping和HandlerAdapter,以使它們非同步和非阻塞並啟用 反應性HTTP請求和響應(以RouterFunction和HandlerFunction的形式)。

除了現有的RestTemplate之外,Spring 5中還引入了新的反應式WebClient。

支持響應式編程的HTTP客戶端(例如Reactor,Netty,Undertow)已經適應了一組響應式的ClientHttpRequest和ClientHttpResponse抽象,這些抽象將請求和響應主體公開為Flux <DataBuffer>,並且在讀取和寫入端具有完全的反壓支持。

Spring 5 Framework引入了Reactor作為Reactive Streams規範的實現。

Reactor是下一代Reactive庫,用於在JVM上構建非阻塞應用程式。

Reactor擴展了基本的Reactive Streams Publisher合同,並定義了Flux和Mono API類型,以分別對0..N和0..1的數據序列提供聲明性操作。

Spring Web Reactive利用Servlet 3.1提供的非阻塞I / O併在Servlet 3.1容器上運行。

Spring WebFlux提供了兩種編程模型的選擇。

  1. 帶註釋的控制器:這些與Spring MVC相同,帶有一些Spring-Web模塊提供的附加註釋。Spring MVC和WebFlux控制器都支持Reactive返回類型。此外,WebFlux還支持Reactive @RequestBody參數。
  2. 函數式編程模型:一個基於lambda的輕量級小型庫,它公開實用程式來路由和處理請求。

 

Spring Web響應式與Spring Web MVC

Spring 5彼此相鄰容納了Spring Web Reactive(在spring-web-reactive模塊下)和Spring Web MVC(在spring-webmvc模塊下)。

儘管Spring Web Reactive和Spring Web MVC模塊都共用許多演算法,但是由於Spring Web Reactive能夠在Reactive和非阻塞的Reactive Streams HTTP適配器層上運行,因此它們不共用代碼。

Spring MVC執行需要Servlet容器,而Spring Web Reactive也可以在非Servlet運行時上運行,例如Netty和Undertow。

如果絕對需要帶有Java 8 lambda或Kotlin的輕量級功能性Web框架的無阻塞Web堆棧,則應考慮從Spring MVC應用程式切換到Spring Web Reactive。

響應式編程的基本配置

這是帶有5.0.0 M5版本和WebFlux依賴項的pom.xml。

 1 <parent>
 2     <groupId>org.springframework.boot</groupId>
 3     <artifactId>spring-boot-starter-parent</artifactId>
 4     <version>2.0.0.M5</version>
 5 </parent>
 6 <dependencies>         
 7     <dependency>
 8         <groupId>org.springframework.boot</groupId>
 9         <artifactId>spring-boot-starter-webflux</artifactId>                               </dependency>
10 </dependencies>

 

傳統方法與反應方法

在傳統方法中,執行將被阻止,並將一直等到服務執行完成。在下麵的代碼中,在第一個列印語句之後,程式執行將被阻塞並等待服務執行完成。服務執行完成後,將恢復程式執行並執行第二個列印語句。

1 @GetMapping("/traditional")
2 public List < Product > getAllProducts() {
3     System.out.println("Traditional way started");
4     List < Product > products = prodService.getProducts("traditional");
5     System.out.println("Traditional way completed");
6     return products;
7 }

      

在響應式方法中,程式將繼續執行,而無需等待服務執行的完成。 在下麵的代碼中,在第一個列印語句之後,第二個列印語句將以非阻塞方式執行,而無需等待服務執行完成。將使用產品數據填充Flux流。

1 @GetMapping(value = "/reactive", .TEXT_EVENT_STREAM_VALUE)
2 public Flux < Product > getAll() {
3     System.out.println("Reactive way using Flux started");
4     Flux < Product > fluxProducts = prodService.getProductsStream("Flux");
5     System.out.println("Reactive way using Flux completed");
6     return fluxProducts;
7 }

 

響應式Web客戶端

除了現有的RestTemplate之外,Spring 5還引入了Reactive WebClient。

ClientHttpRequest和ClientHttpResponse抽象將請求和響應主體公開為Flux <DataBuffer>,在讀取和寫入側具有完全的反壓支持。

來自Spring Core的Encoder和Decoder抽象也用於客戶端,用於與類型對象之間的位元組通量序列化。

以下是一個Reactive WebClient的示例,該示例調用終結點並接收和處理Reactive Stream Flux對象。

1 @GetMapping("/accounts/{id}/alerts")
2 public Flux < Alert > getAccountAlerts(@PathVariable Long id) {
3     WebClient webClient = new WebClient(new ReactorClientHttpConnector());
4     return this.repository.getAccount(id).flatMap(account -> webClient.perform(get("/alerts/{key}", account.getKey())).extract(bodyStream(Alert.class)));
5 }

 

Spring 5的局限性

  • 對響應式應用程式進行故障排除有些困難,並且有可能在解決問題時偶然引入了阻止代碼。
  • 大多數傳統的基於Java的集成庫仍處於阻塞狀態。
  • 除少數NoSQL資料庫(例如MongoDB)外,Reactive數據存儲區提供有限的選項。
  • 仍然不支持Spring Security。

感謝閱讀!

另外近期整理了一套完整的java架構思維導圖,分享給同樣正在認真學習的每位朋友~


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本次講解函數,由於內容比較多,小編列了個大綱,主要有一下內容: 1. 函數基本語法及特性 2. 函數參數 3.局部變數 4. 返回值 5.嵌套函數 6.遞歸 7.匿名函數 8.高階函數 9.內置函數 1. 函數基本語法及特性 函數的定義:函數是指將一組語句的集合通過一個名字(函數名)封裝起來,要想執 ...
  • 我們都知道,語言嘛,當然是用來溝通交流、傳遞信息的,在人類的世界里,語言的種類非常多,像漢語、英語、日語、法語等等。 所以,我們不妨猜想一下,在電腦的世界里,會不會也是這樣的呢?答案是,的確如此。 為了使電腦能夠理解人的意圖,人類就必須將需解決的問題的思路、方法和手段通過電腦能夠理解的形式告訴... ...
  • 應用 MainModule 正確的方法是將連接組件放置在 MainModule 上, 並將數據集放在窗體或窗體所擁有的 DataModules 上。 MainModule 可以被視為會話的核心。 它是一個特殊用途 DataModule, 它是在每次創建新項目時自動創建並添加到項目中的。 MainMo ...
  • 下圖表示 uniGUI 伺服器的內部結構。 每個 uniGUI 伺服器都有一個ServerModule的副本, 每台伺服器創建一次, 同時根據用戶活動動態創建和銷毀多個Session。 uniGUI Session包含一個稱為MainModule(多個)的專用DataModule , 它為每個Ses ...
  • 在UniGUI的CHM幫助里讀到的。 一定要新建一個其他空白的工程,然後再添加LoginForm LoginForm 是另一種特殊的表單類型, 僅用於登錄目的。 此操作將創建一個與常規窗體外觀相同的空白 LoginForm: LoginForm 是一個名為 TUniLoginForm 的內置類的後代 ...
  • Dubbo是一個遠程調用的框架,對於一個服務提供者,暴露了一個介面供外部消費者調用, 那麼對於提供者自己是否可以調用這個介面,需要什麼特殊處理嗎? 這篇文章就分享下Dubbo關於本地調用的實現機制,以及如何開啟和關閉本地調用。 injvm支持本地調用 使用 Dubbo 本地調用不需做特殊配置,按正常 ...
  • Mixins Mixins(混入功能)相當於多繼承,也就是說可以繼承多個類,使用with關鍵字來實現Mixins的功能。 那麼多個類中有相同的方法時候,會被覆蓋嗎?覆蓋的先後是什麼? class A{ void a(){ print("A.a()..."); } } class B{ void a( ...
  • Dart作為一種高級語言,支持面向對象的很多特性,並且支持基於mixin的繼承方式。 基於mixin的繼承方式是指:一個類可以繼承自多個父類,相當於其他語言里的多繼承。 所有的類都有同一個基類Object,這和特性類似於Java、Objective-C 等語言,Java所有的類也都是繼承自Objec ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...