Tomcat中的Connector配置講解

JBoss使用Tomcat作為Web容器,因此在JBoss中對(duì)于Web容器的配置也類似于在Tomcat中的配置,主要就是對(duì)于 server.xml文件的編輯,在JBoss 5.x中,這個(gè)文件位于${JBOSS.HOME}\server\${confifure}\deploy\jbossweb.sar下,其中 configure的值可以是all, default,web,standard, minimal等。下面的代碼展示了一個(gè)JBoss default配置下的server.xml,由于篇幅原因,將其中的注釋都已經(jīng)去掉了。

創(chuàng)新互聯(lián)建站專注于鶴山企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站開(kāi)發(fā),商城系統(tǒng)網(wǎng)站開(kāi)發(fā)。鶴山網(wǎng)站建設(shè)公司,為鶴山等地區(qū)提供建站服務(wù)。全流程按需網(wǎng)站設(shè)計(jì),專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)建站專業(yè)和態(tài)度為您提供的服務(wù)

<Server> 
  <Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" /> 
  <Listener className="org.apache.catalina.core.JasperListener" /> 
  <Service name="jboss.web"> 
   <Connector protocol="HTTP/1.1" port="8080" address="${jboss.bind.address}"  
        connectionTimeout="20000" redirectPort="8443" compression="on"  
        compressionMinSize="1" compressableMimeType="text/html,text/xml" /> 
   <Engine name="jboss.web" defaultHost="localhost"> 
     <Realm className="org.jboss.web.tomcat.security.JBossWebRealm" 
      certificatePrincipal="org.jboss.security.auth.certs.SubjectDNMapping" 
      allRolesMode="authOnly" 
      /> 
     <Host name="localhost">  
      <Valve className="org.jboss.web.tomcat.service.jca.CachedConnectionValve" 
      cachedConnectionManagerObjectName="jboss.jca:service=CachedConnectionManager" 
      transactionManagerObjectName="jboss:service=TransactionManager" /> 
     Host> 
   Engine> 
  Service> 
Server> 

在上面的配置文件中,Server是根節(jié)點(diǎn),一個(gè)Server就代表一個(gè)Servlet容器,因此在server.xml中,這個(gè)節(jié)點(diǎn)只能有一個(gè),在Server節(jié)點(diǎn)下,可以存在一個(gè)或者多個(gè)Service節(jié)點(diǎn)。

一個(gè)Service節(jié)點(diǎn)代表了一個(gè)或者多個(gè)Connector和一個(gè)Engine,而Connector和Engine是在server.xml中兩個(gè)重 要的配置項(xiàng),Connector的主要功能是接受、響應(yīng)用戶請(qǐng)求。常用的Connector有HTTP/1.1 Connector和AJP Connector,HTTP/1.1 Connector主要用于處理用戶的HTTP請(qǐng)求,需要注意的是雖然它名叫HTTP/1.1 Connector,但是是完全兼容HTTP/1.0協(xié)議的。AJP Connector主要使用AJP協(xié)議和Web Connector通信,通常用于集群中。

HTTP/1.1 Connector的實(shí)例監(jiān)聽(tīng)在用戶配置的端口上,當(dāng)應(yīng)用服務(wù)器啟動(dòng)時(shí),HTTP/1.1 Connector負(fù)責(zé)創(chuàng)建若干線程,用于處理用戶請(qǐng)求,創(chuàng)建的線程數(shù)目取決于用戶配置的minThreads值,默認(rèn)為5,當(dāng)有更多的用戶請(qǐng)求到來(lái) 時(shí),HTTP/1.1 Connector將會(huì)創(chuàng)建更多的線程用于處理請(qǐng)求,創(chuàng)建線程的最大值由maxThreads定義,默認(rèn)值為20,當(dāng)所有的線程都在忙于處理用戶請(qǐng)求時(shí), 新到來(lái)的請(qǐng)求將會(huì)放入HTTP/1.1 Connector創(chuàng)建的Socket隊(duì)列中,隊(duì)列的長(zhǎng)度由acceptCount屬性定義,當(dāng)?shù)却?duì)列也被占用滿了,新來(lái)的用戶請(qǐng)求將會(huì)收到connection refused錯(cuò)誤。

所有的Connector提供的配置項(xiàng)(不完全版scheme, isSecure, xpoweredBy, useIPVHosts ):

  • allowTrace 如果需要服務(wù)器能夠處理用戶的HAED/TRACE請(qǐng)求,這個(gè)值應(yīng)該設(shè)置為true,默認(rèn)值是false;
  • emptySessionPath 如果設(shè)置為true,所有session,cookie的path將會(huì)被設(shè)置為/,這種設(shè)置通常是在portlet中比較有用,默認(rèn)值是false;
  • enableLookups 如果需要在調(diào)用request.getRemoteHost()方法時(shí)獲取到客戶端的機(jī)器名,則需要配置為true,如果配置為false,將會(huì)跳過(guò)DNS查詢直接返回客戶端機(jī)器的IP地址,通常為了提高性能,將此值設(shè)置為false,默認(rèn)值是true;
  • maxPostSize POST方法能夠提交的數(shù)據(jù)的最大大小,如果沒(méi)有聲明或者設(shè)置為小于等于0,則表示POST提交的數(shù)據(jù)大小是不限制的,默認(rèn)值是2Megabytes.
  • protocol 設(shè)置處理請(qǐng)求的協(xié)議,默認(rèn)是HTTP/1.1,即org.apache.coyote.http11.Http11Protocol,此外還 支持的協(xié)議有:org.apache.coyote.http11.Http11NioProtocol(通過(guò)NIO處理用戶請(qǐng)求,可以提高系統(tǒng)性能), org.apache.coyote.http11.HttpAprProtocol。
  • proxyName/proxyPort 如果Web服務(wù)器使用了代理服務(wù)器,配置此參數(shù)意味著在調(diào)用request.getServerName的時(shí)候?qū)?huì)獲取代理服務(wù)器的名稱,getServerPort()將會(huì)返回proxyPort。
  • redirectPort 如果Connector的配置是支持非SSL的請(qǐng)求,當(dāng)一個(gè)SSL請(qǐng)求到來(lái)時(shí),服務(wù)器會(huì)自動(dòng)的將請(qǐng)求重定位到redirectPort。
  • URIEncoding URI字節(jié)轉(zhuǎn)化成String的時(shí)候的編碼方式,默認(rèn)為ISO-8859-1,如果頁(yè)面需要支持中文,一般可以將其設(shè)置為UTF-8或者GBK,GB2312。
  • useBodyEncodingForURI 如果設(shè)置為true,則會(huì)根據(jù)頁(yè)面的編碼決定URI的編碼方式,默認(rèn)是false。

Http/1.1 Connector提供的配置項(xiàng):

  • acceptCount 等待隊(duì)列的長(zhǎng)度,默認(rèn)值是100。
  • address 如果Tomcat所在的主機(jī)有多個(gè)IP,這個(gè)值聲明了用于監(jiān)聽(tīng)HTTP請(qǐng)求的IP地址。
  • bufferSize Connector創(chuàng)建的輸入流的大小,默認(rèn)值是2048 bytes,提高這個(gè)值可以提升性能,增加內(nèi)存消耗。
  • compressableMimeType 使用HTTP壓縮的MIME類型,使用逗號(hào)分割,默認(rèn)值是 text/html,text/xml,text/plain。
  • compression 為了節(jié)省帶寬,可以將這個(gè)值設(shè)置為on,從而啟用HTTP/1.1 GZIP壓縮。off關(guān)閉壓縮,forces強(qiáng)制使用壓縮,默認(rèn)值是off。
  • connectionTimeout Connector接受一個(gè)連接后等待的時(shí)間(milliseconds),默認(rèn)值是60000。
  • executor 在Service節(jié)點(diǎn)下,Connector節(jié)點(diǎn)前可以配置一個(gè)Executor節(jié)點(diǎn)用于管理線程,這個(gè)屬性的值是配置的Executor的名稱,如果應(yīng)用了此屬性且executor存在,那么任何其他的關(guān)于thread的配置將會(huì)被忽略。
  • keepAliveTimeout 在Connector關(guān)閉連接前,Connector為另外一個(gè)請(qǐng)求Keep Alive所等待的微妙數(shù),默認(rèn)值和 connectionTimeout 一樣。
  • maxHttpHeaderSize HTTP請(qǐng)求、響應(yīng)頭信息的最大大小,默認(rèn)是8192bytes。
  • maxKeepAliveRequests HTTP/1.0 Keep Alive 和HTTP/1.1 Keep Alive / Pipeline的最大請(qǐng)求數(shù)目,如果設(shè)置為1,將會(huì)禁用掉Keep Alive和Pipeline,如果設(shè)置為小于0的數(shù),Keep Alive的最大請(qǐng)求數(shù)將沒(méi)有限制。默認(rèn)為100。
  • maxThreads 用于處理用戶請(qǐng)求的最大線程數(shù),默認(rèn)值是20。
  • noCompressionUserAgents: 設(shè)置不使用HTTP GZIP壓縮的客戶端,使用逗號(hào)分隔,在某些瀏覽器不支持壓縮的時(shí)候可以使用此屬性。
  • port Connector監(jiān)聽(tīng)的端口。
  • restrictedUserAgents 設(shè)置不使用Keep Alive的客戶端代理名稱,使用逗號(hào)分割,默認(rèn)值是空字符串。
  • server 覆蓋HTTP響應(yīng)的serve頭信息,如果不設(shè)置的話,默認(rèn)值是 Apache-Coyote/1.1。一般情況下不需要關(guān)注此屬性。
  • socketBuffer Socket輸出流緩沖區(qū)的大小,默認(rèn)是9000bytes,如果設(shè)置為小于0的值,則表示不使用此緩沖區(qū)。
  • tcpNoDelay 默認(rèn)值是true,設(shè)置為true可以提高系統(tǒng)性能。
  • threadPriority 請(qǐng)求處理線程的優(yōu)先級(jí),默認(rèn)的優(yōu)先級(jí)是NORMAL。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)創(chuàng)新互聯(lián)的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接

分享標(biāo)題:Tomcat中的Connector配置講解
轉(zhuǎn)載來(lái)源:http://muchs.cn/article44/jepjhe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信小程序、網(wǎng)站制作App開(kāi)發(fā)、域名注冊(cè)ChatGPT、自適應(yīng)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)