SpringBoot2使用Jetty容器操作(替換默認Tomcat)
Jetty和tomcat的比較
Tomcat和Jetty都是一種Servlet引擎,他們都支持標準的servlet規(guī)范和JavaEE的規(guī)范。
架構(gòu)比較
Jetty的架構(gòu)比Tomcat的更為簡單
Jetty的架構(gòu)是基于Handler來實現(xiàn)的,主要的擴展功能都可以用Handler來實現(xiàn),擴展簡單。
Tomcat的架構(gòu)是基于容器設(shè)計的,進行擴展是需要了解Tomcat的整體設(shè)計結(jié)構(gòu),不易擴展。
性能比較
Jetty和Tomcat性能方面差異不大
Jetty可以同時處理大量連接而且可以長時間保持連接,適合于web聊天應(yīng)用等等。
Jetty的架構(gòu)簡單,因此作為服務(wù)器,Jetty可以按需加載組件,減少不需要的組件,減少了服務(wù)器內(nèi)存開銷,從而提高服務(wù)器性能。
Jetty默認采用NIO(非阻塞IO)結(jié)束在處理I/O請求上更占優(yōu)勢,在處理靜態(tài)資源時,性能較高。
Tomcat適合處理少數(shù)非常繁忙的鏈接,也就是說鏈接生命周期短的話,Tomcat的總體性能更高。 另外,Tomcat默認采用BIO(阻塞IO)處理I/O請求,在處理靜態(tài)資源時,性能較差。
Servlet規(guī)范支持方面
Jetty的應(yīng)用更加快速,修改簡單,對新的Servlet規(guī)范的支持較好。 GAE(谷歌應(yīng)用引擎已經(jīng)全面切換為Jetty)
Tomcat目前應(yīng)用比較廣泛,對JavaEE和Servlet的支持更加全面,很多特性會直接集成進來。(中小企業(yè)還再在用)
maven配置
maven的pom.xml只需要排除tomcat并引入jetty即可
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <!-- 使用Jetty,需要在spring-boot-starter-web排除spring-boot-starter-tomcat,因為SpringBoot默認使用tomcat --> <exclusions> <exclusion> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> </exclusion> </exclusions> </dependency> <!-- Jetty適合長連接應(yīng)用,就是聊天類的長連接 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jetty</artifactId> </dependency>
application.yml配置
配置方面,保持之前的內(nèi)容即可。
server.port和server.servlet.context-path的配置不變,
server:
port: 1314
servlet:
context-path: /xxxx
#jetty配置,主要是acceptors和selectors
jetty:
acceptors: 2
selectors: 4
#tomcat的配置可以保留,切換回來可用,反正不會生效
tomcat:
remote-ip-header: x-forward-for
uri-encoding: UTF-8
max-threads: 2000
#background-processor-delay: 30
max-http-header-size: 8096
basedir: ${user.home}/tomcat/tmp
max-connections: 5000
max-http-post-size: 10000000
connection-timeout: 600000
application.properties配置
如果properties可以配置如下
####Jetty properties########
server.jetty.acceptors=2 # acceptor線程數(shù)
server.jetty.max-http-post-size=0 # put或post方法最大字節(jié)數(shù)
server.jetty.selectors=4 # selector線程數(shù)
Jetty參數(shù)解讀
Jetty的線程架構(gòu)模型非常簡單,分為acceptors,selectors和workers三個線程池。acceptors負責接受新連接,然后交給selectors處理HTTP消息協(xié)議的解包,最后由workers處理請求。前兩個線程池采用非阻塞模型,一個線程可以處理很多socket的讀寫,所以線程池數(shù)量較小。
大多數(shù)項目,acceptors線程只需要1-2個,selectors線程配置2~4個足矣。workers是阻塞性的業(yè)務(wù)邏輯,往往有較多的數(shù)據(jù)庫操作,需要的線程數(shù)量較多,具體數(shù)量隨應(yīng)用程序的QPS和IO事件占比而定。QPS越高,需要的線程數(shù)量越多,IO占比越高,等待的線程數(shù)越多,需要的總線程數(shù)也越多。
補充知識:SpringBoot 2.1.x整合Jetty容器
pom.xml依賴
<dependencies> <!--WEB 模塊--> <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> <!--Jetty容器--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jetty</artifactId> </dependency> </dependencies>
Jetty容器相關(guān)參數(shù)
測試
以上這篇SpringBoot2使用Jetty容器操作(替換默認Tomcat)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Springboot中RedisTemplate設(shè)置String、Hash、List過期時間
本文主要介紹了Springboot中RedisTemplate設(shè)置String、Hash、List過期時間,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-05-05IDEA?服務(wù)器熱部署圖文詳解(On?Update?action/On?frame?deactivation)
這篇文章主要介紹了IDEA?服務(wù)器熱部署詳解(On?Update?action/On?frame?deactivation),本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-03-03java 中模擬UDP傳輸?shù)陌l(fā)送端和接收端實例詳解
這篇文章主要介紹了java 中模擬UDP傳輸?shù)陌l(fā)送端和接收端實例詳解的相關(guān)資料,需要的朋友可以參考下2017-03-03springboot?ElasticSearch如何配置自定義轉(zhuǎn)換器ElasticsearchCustomConver
這篇文章主要介紹了springboot?ElasticSearch如何配置自定義轉(zhuǎn)換器ElasticsearchCustomConversions問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-08-08Javabean簡介_動力節(jié)點Java學(xué)院整理
這篇文章主要介紹了Javabean簡介,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07Java實現(xiàn)發(fā)送短信驗證碼+redis限制發(fā)送的次數(shù)功能
這篇文章主要介紹了Java實現(xiàn)發(fā)送短信驗證碼+redis限制發(fā)送的次數(shù),本文通過示例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-04-04