91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Spring賭上未來(lái)的一擊,響應(yīng)式的WebFlux框架更優(yōu)雅

jf_ro2CN3Fa ? 來(lái)源:CSDN ? 2023-06-21 14:42 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

Spring-webflux簡(jiǎn)介

spring-webflux是spring在5.0版本后提供的一套響應(yīng)式編程風(fēng)格的web開(kāi)發(fā)框架。

這個(gè)框架包含了spring-framework和spring mvc,它可以運(yùn)行在Netty、Undertow以及3.1版本以上的Serlvet容器上。

你可以在項(xiàng)目中同時(shí)使用spring-webmvc和spring-webflux,或者只用其中一個(gè)來(lái)開(kāi)發(fā)web應(yīng)用。

什么是“響應(yīng)式”

所謂響應(yīng)式,舉個(gè)例子,當(dāng)調(diào)用一個(gè)api獲取數(shù)據(jù)時(shí),無(wú)需阻塞等待數(shù)據(jù)返回,而是當(dāng)有數(shù)據(jù)返回時(shí)會(huì)進(jìn)行告知??梢?jiàn)響應(yīng)式是非阻塞的,意味著調(diào)用方法后,CPU可以去做別的事情,當(dāng)接收到數(shù)據(jù)響應(yīng)時(shí)CPU再回來(lái)處理,這種方式提高了系統(tǒng)的吞吐量。

而響應(yīng)式編程,其實(shí)是為這種異步非阻塞的流式編程制定的一套標(biāo)準(zhǔn)。流式編程已不陌生了,Java8提供的stream api就是這種風(fēng)格。這套標(biāo)準(zhǔn)包括對(duì)運(yùn)行環(huán)境(JVM、JavaScript)以及網(wǎng)絡(luò)協(xié)議相關(guān)的規(guī)范。

Spring-webflux的響應(yīng)式API

Spring-webflux框架是基于Reactor這個(gè)開(kāi)源項(xiàng)目開(kāi)發(fā)的。Reactor框架是跟Spring緊密配合的。

它提供了兩種API類型,分別是Mono和Flux;

//Mono一般作用于單個(gè)對(duì)象
Monoperson=personDao.getPerson(personId);
//Flux一般作用于多個(gè)對(duì)象
Fluxpeople=personDao.listAllPeople();

盡管webflux框架基于Reactor,它也能與其他的響應(yīng)式框架同時(shí)使用,比如RxJava。

選擇Spring-webmvc還是Spring-webflux呢

這兩個(gè)web框架分別代表著兩種不同類型的編程流派,官方給出了一個(gè)圖作為對(duì)比如下

ea8c3364-0fd3-11ee-962d-dac502259ad0.png

根據(jù)官方的建議有以下幾點(diǎn)可以作為參考:

如果你已經(jīng)使用了 Spring-webmvc 進(jìn)行開(kāi)發(fā),并且項(xiàng)目運(yùn)行良好,就無(wú)需更改了;何況現(xiàn)在大多數(shù)的三方庫(kù)都是阻塞的,并不能發(fā)揮出非阻塞的優(yōu)勢(shì)。

webflux 提供了相當(dāng)多的選擇;在服務(wù)層,可以使用(Netty, Tomcat, Jetty, Undertow, 和3.1版本以上的Servlet容器)作為web服務(wù);在應(yīng)用層,可以選擇用 @Controller 定義還是使用函數(shù)編程定義;在編程風(fēng)格上,可以選擇用Reactor、RxJava或其他。

如果你鐘愛(ài)Java8提供的lambda表達(dá)式這種輕量級(jí)、函數(shù)式的編程風(fēng)格,那么建議選擇用webflux;同時(shí)對(duì)于一些輕量級(jí)應(yīng)用,或者復(fù)雜度比較低的微服務(wù),建議使用webflux以便更好的進(jìn)行控制。

在微服務(wù)架構(gòu)中,可以將webmvc和webflux項(xiàng)目混合使用。兩個(gè)框架都可以使用 @Controller 這種注解的方式,使得項(xiàng)目的重用更加容易。

評(píng)估一個(gè)項(xiàng)目是否應(yīng)該選擇webflux的最簡(jiǎn)單的方式是,依據(jù)項(xiàng)目中是否會(huì)使用很多的阻塞API,比如JDBC或者一些阻塞式的API就不適用與webflux項(xiàng)目。

如果一個(gè)webmvc項(xiàng)目中有很多的外部系統(tǒng)調(diào)用,可以試試響應(yīng)式的 WebClient ,它能直接從 Controller 的方法中返回響應(yīng)式結(jié)果。

響應(yīng)式編程的學(xué)習(xí)路線是比較陡峭的,所以如果你身在一個(gè)大型的團(tuán)隊(duì)中,要考慮投入的成本;不過(guò)可以用用 WebClient 來(lái)體驗(yàn)下響應(yīng)式編程。

Spring-webflux不僅可以支持在Tomcat、Jetty以及3.1版本以上的Servlet容器上,還能夠運(yùn)行在非Servlet的服務(wù)器之上,比如Netty、Undertow等。

使用Springboot構(gòu)建一個(gè)webflux應(yīng)用,默認(rèn)就是使用Netty,因?yàn)镹etty本身就是非阻塞式的實(shí)現(xiàn)。

并發(fā)模型

盡管webmvc和webflux都支持使用注解來(lái)定義一個(gè)Controller,但是其實(shí)現(xiàn)方式完全不同。

webmvc是一個(gè)Servlet應(yīng)用,實(shí)現(xiàn)是阻塞式IO,其維護(hù)一個(gè)線程池來(lái)處理每一個(gè)用戶請(qǐng)求,也就是當(dāng)Servlet容器啟動(dòng)時(shí),就會(huì)創(chuàng)建比如10個(gè)線程出來(lái),因此系統(tǒng)吞吐量的瓶頸在于有限的連接數(shù)和阻塞的請(qǐng)求處理過(guò)程。

webflux可以基于netty這樣的NIO網(wǎng)絡(luò)框架,它只需要很少的幾個(gè)工作線程(Event loop worker)就能夠處理并響應(yīng)請(qǐng)求。由于無(wú)需阻塞等待方法返回,CPU資源就得到了更好的利用。

webflux并不能讓程序運(yùn)行地更快;而是提高了并發(fā)處理請(qǐng)求的能力,即提高了系統(tǒng)吞吐量。

webflux代碼示例

Talk is cheap, show me the code

下面讓我們來(lái)看一下webflux的示例,總的來(lái)說(shuō)使用上是非常便捷的。

我們用Springboot構(gòu)建一個(gè)webflux應(yīng)用非常簡(jiǎn)單,僅僅需要加入這么一個(gè)依賴


org.springframework.boot
spring-boot-starter-webflux

首先定義一個(gè)對(duì)象

publicclassPerson{
privateIntegerid;
privateIntegerage;
privateStringname;
}

然后定義“PersonController”,響應(yīng)式風(fēng)格中不再使用@RequestMapping聲明地址映射了,而是通過(guò)RouterFunctions.route().GET()方法

@Configuration
publicclassPersonRouter{
@Resource
privatePersonHandlerpersonHandler;
@Bean
publicRouterFunctionpersonRoutes(){
returnRouterFunctions.route()
.GET("/person/{id}",RequestPredicates.accept(MediaType.APPLICATION_JSON),personHandler::getPerson)
.GET("/person",RequestPredicates.accept(MediaType.APPLICATION_JSON),personHandler::listPeople)
.POST("/person",personHandler::createPerson)
.build();
}
}

在PersonHandler中處理對(duì)應(yīng)的HTTP請(qǐng)求,等同于MVC架構(gòu)中的Service層

@Component
publicclassPersonHandler{

@Resource
privatePersonRepositorypersonDao;

publicMonolistPeople(ServerRequestrequest){
Fluxpeople=personDao.listAllPeople();
returnServerResponse.ok()
.contentType(MediaType.APPLICATION_JSON)
.body(people,Person.class);
}

publicMonocreatePerson(ServerRequestrequest){
Monoperson=request.bodyToMono(Person.class);
returnServerResponse.ok()
.build(personDao.savePerson(person));
}

publicMonogetPerson(ServerRequestrequest){
intpersonId=Integer.parseInt(request.pathVariable("id"));
returnpersonDao.getPerson(personId)
.flatMap(person->ServerResponse.ok().contentType(MediaType.APPLICATION_JSON).bodyValue(person))
.switchIfEmpty(ServerResponse.notFound().build());
}

}

通過(guò)啟動(dòng)日志可以證實(shí)Spring-webflux是默認(rèn)使用Netty提供HTTP服務(wù)

ea9860a8-0fd3-11ee-962d-dac502259ad0.png

項(xiàng)目啟動(dòng)之后瀏覽器就能發(fā)現(xiàn),你的Spring-webflux項(xiàng)目已經(jīng)正常工作了。





審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • Web服務(wù)器
    +關(guān)注

    關(guān)注

    0

    文章

    139

    瀏覽量

    25266
  • JAVA語(yǔ)言
    +關(guān)注

    關(guān)注

    0

    文章

    138

    瀏覽量

    21520
  • JDBC
    +關(guān)注

    關(guān)注

    0

    文章

    25

    瀏覽量

    13851
  • HTTP接口
    +關(guān)注

    關(guān)注

    0

    文章

    21

    瀏覽量

    2073

原文標(biāo)題:Spring 賭上未來(lái)的一擊,響應(yīng)式的 WebFlux 框架更優(yōu)雅,性能更強(qiáng)!

文章出處:【微信號(hào):芋道源碼,微信公眾號(hào):芋道源碼】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    英偉達(dá)5萬(wàn)億市值背后,是場(chǎng)未來(lái)的燒錢競(jìng)賽

    需求下,各大云計(jì)算廠商不斷加大對(duì)AI算力基建的投資,大量購(gòu)買算力卡。在10月29日的GTC大會(huì)上,英偉達(dá)CEO黃仁勛表示,公司新代AI芯片有望在未來(lái)幾個(gè)季度創(chuàng)造高達(dá)5000億美元的收入,遠(yuǎn)超市場(chǎng)預(yù)期。 ? 5000億美元的收入從何而來(lái)?在亞馬遜、谷
    的頭像 發(fā)表于 11-02 11:18 ?1.1w次閱讀
    英偉達(dá)5萬(wàn)億市值背后,是<b class='flag-5'>一</b>場(chǎng)<b class='flag-5'>賭</b><b class='flag-5'>上</b><b class='flag-5'>未來(lái)</b>的燒錢競(jìng)賽

    LuatOS框架的使用(

    在資源受限的物聯(lián)網(wǎng)終端設(shè)備中,如何實(shí)現(xiàn)快速開(kāi)發(fā)與穩(wěn)定運(yùn)行是關(guān)鍵挑戰(zhàn)。LuatOS框架通過(guò)將Lua語(yǔ)言與底層硬件抽象層深度融合,提供了套簡(jiǎn)潔高效的開(kāi)發(fā)范式。本文將圍繞LuatOS框架的使用展開(kāi),從
    的頭像 發(fā)表于 01-27 19:38 ?151次閱讀
    LuatOS<b class='flag-5'>框架</b>的使用(<b class='flag-5'>上</b>)

    使用xmake+zig更優(yōu)雅的進(jìn)行嵌入系統(tǒng)開(kāi)發(fā)

    ,在嵌入領(lǐng)域采用現(xiàn)代化構(gòu)建工具鏈已成為提升開(kāi)發(fā)效率的趨勢(shì)。LLVM在嵌入領(lǐng)域有兩類應(yīng)用方案:是由芯片廠商提供的平臺(tái)專用集成工具鏈(如armclang、LLV
    的頭像 發(fā)表于 11-30 10:04 ?4515次閱讀
    使用xmake+zig<b class='flag-5'>更優(yōu)雅</b>的進(jìn)行嵌入<b class='flag-5'>式</b>系統(tǒng)開(kāi)發(fā)

    PYQT 應(yīng)用程序框架及開(kāi)發(fā)工具

    大家好,本團(tuán)隊(duì)此次分享的內(nèi)容為開(kāi)發(fā)過(guò)程中使用到的PYQT 應(yīng)用程序框架及開(kāi)發(fā)工具。 pYqt 是個(gè)多平臺(tái)的 python 圖形用戶界面應(yīng)用程序框架,由于其面向?qū)ο蟆? 易擴(kuò)展(可實(shí)現(xiàn)組件編程等
    發(fā)表于 10-29 07:15

    能電氣與中石油濟(jì)柴簽署框架合作協(xié)議

    近日,能電氣股份有限公司(以下簡(jiǎn)稱“能電氣”)與中國(guó)石油集團(tuán)濟(jì)柴動(dòng)力有限公司(以下簡(jiǎn)稱“中石油濟(jì)柴”)在上能電氣總部簽署框架合作協(xié)議。
    的頭像 發(fā)表于 10-11 16:13 ?587次閱讀

    嵌入工程師為什么要學(xué)QT?

    Qt對(duì)嵌入工程師來(lái)說(shuō),真的很重要嗎? Qt是個(gè)跨平臺(tái)的C++應(yīng)用程序開(kāi)發(fā)框架,非常適合嵌入系統(tǒng)的開(kāi)發(fā),Qt在嵌入開(kāi)發(fā)中具有很重要的作
    發(fā)表于 08-14 15:15

    BitsButton嵌入按鍵處理框架

    BitsButton 、簡(jiǎn)介? ??BitsButton是款針對(duì)嵌入系統(tǒng)優(yōu)化的按鍵檢測(cè)框架??。通過(guò)創(chuàng)新的二進(jìn)制位序列技術(shù),它能高效處理單鍵、組合鍵(如Ctrl+C)和復(fù)雜按鍵
    發(fā)表于 08-02 11:24

    西井科技推出Hymala多聯(lián)運(yùn)物流樞紐大模型矩陣

    聯(lián)運(yùn)物流樞紐中多源需求、跨系統(tǒng)任務(wù)與多要素協(xié)同的全鏈路智能統(tǒng)籌難題,致力于構(gòu)建具備深度思考與協(xié)同能力的物流“智能大腦”,以積極響應(yīng)行業(yè)對(duì)于“高效化、綠色化”運(yùn)營(yíng)的迫切需求,引領(lǐng)智慧物流的
    的頭像 發(fā)表于 07-29 17:49 ?1650次閱讀

    Spring攔截器:你的請(qǐng)求休想逃過(guò)我的五指山!

    Spring框架中,攔截器(Interceptor)是種強(qiáng)大的機(jī)制,它允許開(kāi)發(fā)者在請(qǐng)求處理的不同階段插入自定義邏輯。WebApplicationContext作為Spring We
    的頭像 發(fā)表于 07-26 11:25 ?682次閱讀
    <b class='flag-5'>Spring</b>攔截器:你的請(qǐng)求休想逃過(guò)我的五指山!

    潤(rùn)和軟件StackRUNS異構(gòu)分布推理框架的應(yīng)用案例

    江蘇潤(rùn)和軟件股份有限公司(以下簡(jiǎn)稱“潤(rùn)和軟件”)自主研發(fā)的StackRUNS異構(gòu)分布推理框架已在實(shí)際場(chǎng)景中取得顯著成效,成功應(yīng)用于大型園區(qū)多模態(tài)模型演練及高校滿血版DeepSeek-MoE 671B的運(yùn)行,有效推動(dòng)了大模型技術(shù)的快速落地。
    的頭像 發(fā)表于 06-13 09:11 ?1302次閱讀
    潤(rùn)和軟件StackRUNS異構(gòu)分布<b class='flag-5'>式</b>推理<b class='flag-5'>框架</b>的應(yīng)用案例

    振弦滲壓計(jì)的響應(yīng)時(shí)間與測(cè)量頻率解析

    在水利工程、巖土監(jiān)測(cè)等領(lǐng)域,振弦滲壓計(jì)是監(jiān)測(cè)結(jié)構(gòu)物內(nèi)部滲透水壓力的重要工具。其核心價(jià)值在于能夠長(zhǎng)期穩(wěn)定地提供精準(zhǔn)數(shù)據(jù),幫助工程師評(píng)估工程安全狀態(tài)。對(duì)于用戶而言,了解其響應(yīng)時(shí)間和測(cè)量頻率的特性
    的頭像 發(fā)表于 06-12 10:46 ?590次閱讀
    振弦<b class='flag-5'>式</b>滲壓計(jì)的<b class='flag-5'>響應(yīng)</b>時(shí)間與測(cè)量頻率解析

    CodeBuddy 打造響應(yīng)圖片畫(huà)廊

    我正在參加CodeBuddy「首席試玩官」內(nèi)容創(chuàng)作大賽,本文所使用的 CodeBuddy 免費(fèi)下載鏈接: 騰訊云代碼助手 CodeBuddy - AI 時(shí)代的智能編程伙伴 前段時(shí)間,我打算做個(gè)響應(yīng)
    的頭像 發(fā)表于 05-11 13:33 ?635次閱讀
    CodeBuddy 打造<b class='flag-5'>一</b>款<b class='flag-5'>響應(yīng)</b><b class='flag-5'>式</b>圖片畫(huà)廊

    文讀懂什么是電源瞬態(tài)響應(yīng)

    您注意過(guò)在啟動(dòng)空調(diào)以后屋里的燈光瞬間變暗的情況嗎?這是因?yàn)榭照{(diào)吸收了大量電流,致使供電電壓下降,進(jìn)而導(dǎo)致了燈光變暗。小段時(shí)間之后,電壓還會(huì)恢復(fù)正常。直流電源的輸出阻抗,也會(huì)造成類似的電壓瞬變
    的頭像 發(fā)表于 04-23 17:31 ?1903次閱讀
    <b class='flag-5'>一</b>文讀懂什么是電源瞬態(tài)<b class='flag-5'>響應(yīng)</b>

    推薦!如何優(yōu)雅地?cái)[好PCB絲印?

    很多畫(huà)PCB的人,會(huì)認(rèn)為絲印不影響電路的性能,所以,對(duì)絲印并不重視。但是,對(duì)于個(gè)專業(yè)的硬件工程師來(lái)說(shuō),必須重視這些細(xì)節(jié)。 下面介紹如何優(yōu)雅地弄好PCB絲印。 1 擺放的位置 般來(lái)說(shuō),電阻、電容
    發(fā)表于 04-08 14:59

    恩智浦講解如何在低算力MCU平臺(tái)上優(yōu)雅的計(jì)算均值和方差

    本文主要探討如何在有限的計(jì)算能力和內(nèi)存條件下,優(yōu)雅地實(shí)現(xiàn)高效的均值和方差計(jì)算。通過(guò)優(yōu)化算法、減少計(jì)算復(fù)雜度、利用遞推公式和定點(diǎn)數(shù)運(yùn)算,文章提供了系列使用技巧,幫忙開(kāi)發(fā)者在保持精度的同時(shí),顯著降低計(jì)算開(kāi)銷。這些方法特別適用于物聯(lián)網(wǎng)設(shè)備、嵌入
    的頭像 發(fā)表于 03-06 08:56 ?1650次閱讀
    恩智浦講解如何在低算力MCU平臺(tái)上<b class='flag-5'>優(yōu)雅</b>的計(jì)算均值和方差