在Spring?Boot使用Undertow服務的方法
在Spring Boot使用Undertow服務
1.undertow簡介
Undertow是RedHAT紅帽公司開源的產品,采用JAVA開發(fā),是一款靈活,高性能的web服務器,提供了NIO的阻塞/非阻塞API,也是Wildfly的默認Web容器。在javaweb容器的世界里,Tomcat和jetty是大眾熟知的,undertow目前逐步進入大眾的視角,它是一款能和tomcat媲美的神器,在性能方面吊打tomcat。目前Undertow已經成為springboot 默認集成的三大容器之一。
2.undertow特點
undertow在高并發(fā)業(yè)務場景中,性能優(yōu)于tomcat
高性能,在多款同類產品的壓測對比中,高并發(fā)情況下表現出色。Servlet4.0支持,它提供了對Servlet4.0的支持。Web Socket完全支持,包含JSR-356,用以滿足Web應用巨大數量的客戶端。內嵌式,它不需要容器,只需要通過api即可快速搭建Web服務器。靈活性,交由鏈式Handler配置和處理請求,可以最小化按需加載模塊,無須加載多余功能。輕量級,它是一個內嵌Web服務器,由兩個核心jar包組成。 3.springboot集成的web服務器
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.7.4</version> </parent> <groupId>com.konne</groupId> <artifactId>push-demo</artifactId> <version>0.0.1-SNAPSHOT</version> <name>push-demo</name> <description>Demo project for Spring Boot</description> <properties> <java.version>1.8</java.version> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <!-- 移除掉默認支持的 Tomcat --> <exclusions> <exclusion> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> </exclusion> </exclusions> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-undertow</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </project>
配置啟動成功顯示如下信息:
. ____ _ __ _ _
/\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
\\/ ___)| |_)| | | | | || (_| | ) ) ) )
' |____| .__|_| |_|_| |_\__, | / / / /
=========|_|==============|___/=/_/_/_/
:: Spring Boot :: (v2.7.4)2022-12-13 09:41:21.625 INFO 2416 --- [ main] com.konne.pushdemo.PushDemoApplication : Starting PushDemoApplication using Java 1.8.0_202 on 2F-KF03 with PID 2416 (D:\i-word\push-demo\target\classes started by Administrator in D:\i-word\push-demo)
2022-12-13 09:41:21.628 INFO 2416 --- [ main] com.konne.pushdemo.PushDemoApplication : No active profile set, falling back to 1 default profile: "default"
2022-12-13 09:41:22.226 WARN 2416 --- [ main] io.undertow.websockets.jsr : UT026010: Buffer pool was not set on WebSocketDeploymentInfo, the default pool will be used
2022-12-13 09:41:22.241 INFO 2416 --- [ main] io.undertow.servlet : Initializing Spring embedded WebApplicationContext
2022-12-13 09:41:22.241 INFO 2416 --- [ main] w.s.c.ServletWebServerApplicationContext : Root WebApplicationContext: initialization completed in 578 ms
2022-12-13 09:41:22.482 INFO 2416 --- [ main] io.undertow : starting server: Undertow - 2.2.19.Final
2022-12-13 09:41:22.486 INFO 2416 --- [ main] org.xnio : XNIO version 3.8.7.Final
2022-12-13 09:41:22.490 INFO 2416 --- [ main] org.xnio.nio : XNIO NIO Implementation Version 3.8.7.Final
2022-12-13 09:41:22.514 INFO 2416 --- [ main] org.jboss.threads : JBoss Threads version 3.1.0.Final
2022-12-13 09:41:22.544 INFO 2416 --- [ main] o.s.b.w.e.undertow.UndertowWebServer : Undertow started on port(s) 8080 (http)
2022-12-13 09:41:22.552 INFO 2416 --- [ main] com.konne.pushdemo.PushDemoApplication : Started PushDemoApplication in 1.217 seconds (JVM running for 1.807)
SpringBoot使用Undertow做服務器
說明
undertow,jetty和tomcat可以說是javaweb項目當下最火的三款服務器,tomcat是apache下的一款重量級的服務器,不用多說歷史悠久,經得起實踐的考驗。然而:當下微服務興起,spring boot ,spring cloud 越來越熱的情況下,選擇一款輕量級而性能優(yōu)越的服務器是必要的選擇。spring boot 完美集成了tomcat,jetty和undertow,本文將通過對jetty和undertow服務器的分析以及測試,來比較兩款服務器的性能如何。
值得一提的是jetty和undertow都是基于NIO實現的高并發(fā)輕量級的服務器,支持servlet3.1和websocket。所以,有必要先了解下什么是NIO。
NIO(非阻塞式輸入輸出)
- Channel
- Selector
- Buffer
- Acceptor
Client和Server只向Buffer讀寫數據不關注數據的流向,數據通過Channel通道進行流轉。而Selector是存在與服務端的,用于Channel的注冊以此實現數據I/O操作。Acceptor負責接受所以的連接通道并且注冊到Channel中。而整個過程客戶端與服務端是非阻塞的也就是異步操作。
下面是壓力測試對比圖:
服務器 | 命中 | 成功率 | 吞吐量 | 平均耗時 |
Jetty | 11488 | 100% | 96.25 trans/sec | 0.00sec |
18393 | 100% | 153.92 trans/sec | 0.01sec | |
21484 | 99.99% | 179.51 trans/sec | 0.01sec | |
Undertow | 11280 | 100% | 94.02 trans/sec | 0.00sec |
19442 | 100% | 163.35 trans/sec | 0.01sec | |
23277 | 100% | 195.54 tran/sec | 0.01sec | |
Tomcat | 10845 | 100% | 90.95 trans/sec | 0.02sec |
21673 | 99.98% | 181 trans/sec | 0.01sec | |
25084 | 99.98% | 209.10 trans/sec | 0.01sec |
從中可以看出在高負載下Undertow的吞吐量高于Jetty而且隨著壓力增大Jetty和Undertow成功率差距會拉大。而在負載不是太大情況下服務器處理能力差不多,jetty還略微高于Undertow。而tomcat的負載能力似乎和Undertow很接近。
對比三個服務器發(fā)現在Undertow在負載過重情況下比Jetty和Tocmat更加頑強,實踐證明在負載繼續(xù)加大情況下Undertow的成功率高于其它兩者,但是在并發(fā)不是太大情況下三款服務器整體來看差別不大。
從中可以看出在高負載下Undertow的吞吐量高于Jetty而且隨著壓力增大Jetty和Undertow成功率差距會拉大。而在負載不是太大情況下服務器處理能力差不多,jetty還略微高于Undertow。而tomcat的負載能力似乎和Undertow很接近。
對比三個服務器發(fā)現在Undertow在負載過重情況下比Jetty和Tocmat更加頑強,實踐證明在負載繼續(xù)加大情況下Undertow的成功率高于其它兩者,但是在并發(fā)不是太大情況下三款服務器整體來看差別不大。
快速開始
更新pom.xml文件:
<!--<dependency>--> <!--<groupId>org.springframework.boot</groupId>--> <!--<artifactId>spring-boot-starter-web</artifactId>--> <!--</dependency>--> <!-- 下面的配置將使用undertow來做服務器而不是tomcat --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <exclusions> <exclusion> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> </exclusion> </exclusions> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-undertow</artifactId> </dependency>
application.yml配置:
server: port: 8081 # 下面是配置undertow作為服務器的參數 undertow: # 設置IO線程數, 它主要執(zhí)行非阻塞的任務,它們會負責多個連接, 默認設置每個CPU核心一個線程 io-threads: 4 # 阻塞任務線程池, 當執(zhí)行類似servlet請求阻塞操作, undertow會從這個線程池中取得線程,它的值設置取決于系統(tǒng)的負載 worker-threads: 20 # 以下的配置會影響buffer,這些buffer會用于服務器連接的IO操作,有點類似netty的池化內存管理 # 每塊buffer的空間大小,越小的空間被利用越充分 buffer-size: 1024 # 是否分配的直接內存 direct-buffers: true
配置比較簡單,和tomcat使用基本一樣,然后就可以快樂的使用undertow啦~
到此這篇關于在Spring Boot使用Undertow服務的文章就介紹到這了,更多相關Spring Boot使用Undertow服務內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Java Apache Shiro安全框架快速開發(fā)詳解流程
Apache Shiro是一個強大且易用的Java安全框架,執(zhí)行身份驗證、授權、密碼和會話管理。使用Shiro的易于理解的API,您可以快速、輕松地獲得任何應用程序,從最小的移動應用程序到最大的網絡和企業(yè)應用程序2021-10-10springboot使用alibaba的druid數據庫連接池錯誤的問題及解決
這篇文章主要介紹了springboot使用alibaba的druid數據庫連接池錯誤的問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-02-02