SpringBoot2使用Jetty容器操作(替換默認(rèn)Tomcat)
Jetty和tomcat的比較
Tomcat和Jetty都是一種Servlet引擎,他們都支持標(biāo)準(zhǔn)的servlet規(guī)范和JavaEE的規(guī)范。
架構(gòu)比較
Jetty的架構(gòu)比Tomcat的更為簡單
Jetty的架構(gòu)是基于Handler來實(shí)現(xiàn)的,主要的擴(kuò)展功能都可以用Handler來實(shí)現(xiàn),擴(kuò)展簡單。
Tomcat的架構(gòu)是基于容器設(shè)計(jì)的,進(jìn)行擴(kuò)展是需要了解Tomcat的整體設(shè)計(jì)結(jié)構(gòu),不易擴(kuò)展。
性能比較
Jetty和Tomcat性能方面差異不大
Jetty可以同時(shí)處理大量連接而且可以長時(shí)間保持連接,適合于web聊天應(yīng)用等等。
Jetty的架構(gòu)簡單,因此作為服務(wù)器,Jetty可以按需加載組件,減少不需要的組件,減少了服務(wù)器內(nèi)存開銷,從而提高服務(wù)器性能。
Jetty默認(rèn)采用NIO(非阻塞IO)結(jié)束在處理I/O請(qǐng)求上更占優(yōu)勢(shì),在處理靜態(tài)資源時(shí),性能較高。
Tomcat適合處理少數(shù)非常繁忙的鏈接,也就是說鏈接生命周期短的話,Tomcat的總體性能更高。 另外,Tomcat默認(rèn)采用BIO(阻塞IO)處理I/O請(qǐng)求,在處理靜態(tài)資源時(shí),性能較差。
Servlet規(guī)范支持方面
Jetty的應(yīng)用更加快速,修改簡單,對(duì)新的Servlet規(guī)范的支持較好。 GAE(谷歌應(yīng)用引擎已經(jīng)全面切換為Jetty)
Tomcat目前應(yīng)用比較廣泛,對(duì)JavaEE和Servlet的支持更加全面,很多特性會(huì)直接集成進(jìn)來。(中小企業(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,因?yàn)镾pringBoot默認(rèn)使用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的配置可以保留,切換回來可用,反正不會(huì)生效
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三個(gè)線程池。acceptors負(fù)責(zé)接受新連接,然后交給selectors處理HTTP消息協(xié)議的解包,最后由workers處理請(qǐng)求。前兩個(gè)線程池采用非阻塞模型,一個(gè)線程可以處理很多socket的讀寫,所以線程池?cái)?shù)量較小。
大多數(shù)項(xiàng)目,acceptors線程只需要1-2個(gè),selectors線程配置2~4個(gè)足矣。workers是阻塞性的業(yè)務(wù)邏輯,往往有較多的數(shù)據(jù)庫操作,需要的線程數(shù)量較多,具體數(shù)量隨應(yīng)用程序的QPS和IO事件占比而定。QPS越高,需要的線程數(shù)量越多,IO占比越高,等待的線程數(shù)越多,需要的總線程數(shù)也越多。
補(bǔ)充知識(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容器操作(替換默認(rèn)Tomcat)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Maven遠(yuǎn)程倉庫地址修改實(shí)現(xiàn)解析
這篇文章主要介紹了Maven遠(yuǎn)程倉庫地址修改實(shí)現(xiàn)解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11Springboot中RedisTemplate設(shè)置String、Hash、List過期時(shí)間
本文主要介紹了Springboot中RedisTemplate設(shè)置String、Hash、List過期時(shí)間,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-05-05IDEA?服務(wù)器熱部署圖文詳解(On?Update?action/On?frame?deactivation)
這篇文章主要介紹了IDEA?服務(wù)器熱部署詳解(On?Update?action/On?frame?deactivation),本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-03-03java 中模擬UDP傳輸?shù)陌l(fā)送端和接收端實(shí)例詳解
這篇文章主要介紹了java 中模擬UDP傳輸?shù)陌l(fā)送端和接收端實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-03-03springboot?ElasticSearch如何配置自定義轉(zhuǎn)換器ElasticsearchCustomConver
這篇文章主要介紹了springboot?ElasticSearch如何配置自定義轉(zhuǎn)換器ElasticsearchCustomConversions問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08Java實(shí)現(xiàn)一個(gè)簡單的長輪詢的示例代碼
長輪詢是與服務(wù)器保持即時(shí)通信的最簡單的方式,它不使用任何特定的協(xié)議,例如 WebSocket ,所以也不依賴于瀏覽器版本等外部條件的兼容性。本文將用Java實(shí)現(xiàn)一個(gè)簡單的長輪詢,需要的可以參考一下2022-08-08Javabean簡介_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了Javabean簡介,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07Java實(shí)現(xiàn)發(fā)送短信驗(yàn)證碼+redis限制發(fā)送的次數(shù)功能
這篇文章主要介紹了Java實(shí)現(xiàn)發(fā)送短信驗(yàn)證碼+redis限制發(fā)送的次數(shù),本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-04-04