溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

SpringBoot2如何使用Jetty容器

發(fā)布時(shí)間:2020-10-28 17:10:43 來(lái)源:億速云 閱讀:522 作者:Leah 欄目:開(kāi)發(fā)技術(shù)

SpringBoot2如何使用Jetty容器?很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。

Jetty和tomcat的比較

Tomcat和Jetty都是一種Servlet引擎,他們都支持標(biāo)準(zhǔn)的servlet規(guī)范和JavaEE的規(guī)范。

架構(gòu)比較

Jetty的架構(gòu)比Tomcat的更為簡(jiǎn)單

Jetty的架構(gòu)是基于Handler來(lái)實(shí)現(xiàn)的,主要的擴(kuò)展功能都可以用Handler來(lái)實(shí)現(xiàn),擴(kuò)展簡(jiǎn)單。

Tomcat的架構(gòu)是基于容器設(shè)計(jì)的,進(jìn)行擴(kuò)展是需要了解Tomcat的整體設(shè)計(jì)結(jié)構(gòu),不易擴(kuò)展。

性能比較

Jetty和Tomcat性能方面差異不大

Jetty可以同時(shí)處理大量連接而且可以長(zhǎng)時(shí)間保持連接,適合于web聊天應(yīng)用等等。

Jetty的架構(gòu)簡(jiǎn)單,因此作為服務(wù)器,Jetty可以按需加載組件,減少不需要的組件,減少了服務(wù)器內(nèi)存開(kāi)銷(xiāo),從而提高服務(wù)器性能。

Jetty默認(rèn)采用NIO(非阻塞IO)結(jié)束在處理I/O請(qǐng)求上更占優(yōu)勢(shì),在處理靜態(tài)資源時(shí),性能較高。

Tomcat適合處理少數(shù)非常繁忙的鏈接,也就是說(shuō)鏈接生命周期短的話,Tomcat的總體性能更高。 另外,Tomcat默認(rèn)采用BIO(阻塞IO)處理I/O請(qǐng)求,在處理靜態(tài)資源時(shí),性能較差。

Servlet規(guī)范支持方面

Jetty的應(yīng)用更加快速,修改簡(jiǎn)單,對(duì)新的Servlet規(guī)范的支持較好。 GAE(谷歌應(yīng)用引擎已經(jīng)全面切換為Jetty)

Tomcat目前應(yīng)用比較廣泛,對(duì)JavaEE和Servlet的支持更加全面,很多特性會(huì)直接集成進(jìn)來(lái)。(中小企業(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適合長(zhǎng)連接應(yīng)用,就是聊天類(lèi)的長(zhǎ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的配置可以保留,切換回來(lái)可用,反正不會(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)模型非常簡(jiǎn)單,分為acceptors,selectors和workers三個(gè)線程池。acceptors負(fù)責(zé)接受新連接,然后交給selectors處理HTTP消息協(xié)議的解包,最后由workers處理請(qǐng)求。前兩個(gè)線程池采用非阻塞模型,一個(gè)線程可以處理很多socket的讀寫(xiě),所以線程池?cái)?shù)量較小。

大多數(shù)項(xiàng)目,acceptors線程只需要1-2個(gè),selectors線程配置2~4個(gè)足矣。workers是阻塞性的業(yè)務(wù)邏輯,往往有較多的數(shù)據(jù)庫(kù)操作,需要的線程數(shù)量較多,具體數(shù)量隨應(yīng)用程序的QPS和IO事件占比而定。QPS越高,需要的線程數(shù)量越多,IO占比越高,等待的線程數(shù)越多,需要的總線程數(shù)也越多。

SpringBoot2如何使用Jetty容器

補(bǔ)充知識(shí):SpringBoot 2.1.x整合Jetty容器

pom.xml依賴(lài)

<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容器

測(cè)試

SpringBoot2如何使用Jetty容器

看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝您對(duì)億速云的支持。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI