【056擴展1 Tomcat的線程池】
在conf的server.xml中通過connector可以改變魏身,默認的線程池是Tomcat自定義的惊橱,類似于ThreadPoolExecutor,通過參數(shù)可以指定核心線程數(shù)和最大線程數(shù)等箭昵,阻塞隊列是繼承了LinkedBlockingQueue的TaskQueue税朴。
【056擴展2 Tomcat是線程安全的嗎?】
Tomcat不是線程安全的家制,因為Tomcat的servlet被包裝在wrapper容器里正林,而相同請求的wrapper只在第一次完成初始化,后面的請求會調(diào)用同一個servlet的doGet和doPost方法颤殴,其成員變量是共享的觅廓。
【057 Tomcat的內(nèi)部架構(gòu)】
Tomcat啟動時,調(diào)用的是BootStrap的run方法涵但,該方法會調(diào)用Catalina生命周期的start方法(之后所有組件的啟動也是依靠各自生命周期的start方法)杈绸,加載conf目錄下的server.xml文件,啟動唯一的Server矮瘟。而Server又會啟動內(nèi)部的多個Service方法瞳脓,每一個Service代表一種類型的Web服務(wù)(A "Service" is a collection of one or more "Connectors" that share a single "Container"),可以有多個Connector澈侠,但只能有一個Engine劫侧。每個Connector指定不同的連接方式,包括協(xié)議哨啃,監(jiān)聽端口號等烧栋。然后通過線程池的線程處理,分析請求拳球,并交給合適的容器审姓。容器的頂層是Engine,一個Engine可以有多個Host祝峻,每個Host是一臺虛擬主機魔吐,而每個Host又可以有多個Context次坡,代表每一個Web應(yīng)用,Context包含多個Wrapper画畅,每個Wrapper封裝一個Java Servlet或者Jasper編譯生成的Jsp Servlet砸琅。不管是哪一個層次的容器或子容器,都可以設(shè)置valve過濾鏈轴踱,處理公共流程症脂。
【057擴展1 Tomcat連接器Connector】
Connextor一般需要指定協(xié)議如protocol="HTTP/1.1"、監(jiān)聽端口號port="8080"淫僻、連接超時如connectionTimeout="20000"诱篷、把客戶請求轉(zhuǎn)發(fā)至SSL的redirectPort="8443"以及線程池executor="tomcatThreadPool"。線程池可以是多個Connector共享的雳灵,也可獨占棕所,需要指定maxThreads和minSpareThreads。
【057擴展2 Tomcat虛擬主機Host】
如果把所有web站點的目錄都放在webapps下悯辙,可能導(dǎo)致磁盤空間不夠用琳省,也不利于對web站點目錄的管理,把web站點的目錄分散到其他磁盤管理就需要配置虛擬目錄(默認情況下躲撰,只有配置在Host的appBase中的目錄针贬,也就是webapps下的目錄才能被Tomcat自動管理成一個web站點)。在server.xml中<Host>的節(jié)點下添加<Context?path="/web1" docBase="D:\web1"/>拢蛋,path表示訪問應(yīng)用名桦他,docBase表示絕對路徑。
【057擴展4 什么是Jasper谆棱?】
Jasper的作用是把Jsp文件轉(zhuǎn)為servlet快压,存放在Tomcat的Work目錄下,每個應(yīng)用會有一個獨立的子目錄垃瞧。轉(zhuǎn)換過程發(fā)生在Server的監(jiān)聽器JasperListener蔫劣。
【推薦文章】https://blog.csdn.net/u012906938/article/details/36718809
【058 Tomcat的生命周期】
Tomcat自帶的所有組件都繼承了Lifecycle接口,實現(xiàn)start和stop方法。Tomcat是通過BootStrap來實現(xiàn)啟停的膀跌,繼承了Lifecycle接口的類會采用觀察者模式,通過事件通知的方式來啟動和停止。以Context為例济赎,其內(nèi)部還有一個LifcycleSupport類型的成員,該類型維護了一個LifecycleListener的數(shù)組草添,調(diào)用Context的start和stop方法時酪劫,除了會通知所屬的Wrapper和Valve組件,還會通知該數(shù)組的所有成員觸發(fā)內(nèi)部注冊的lifecycle的start和stop方法珊蟀。
【059 Tomcat的設(shè)計模式】
①單例模式的擴展StringManager菊值,每個包有一個共享的單例String配置信息外驱;
②裝飾者模式ResponseFacade/RequestFacade,封裝了Response和Request中希望對Tomcat開發(fā)者公開但是對Web開發(fā)者屏蔽的函數(shù)腻窒,因此不能簡單地用public/private權(quán)限昵宇,如對請求的readLine等解析方法;
③ 責任鏈模式管道與閥門儿子;
④ 觀察者模式lifecycle瓦哎。
【060 Tomcat的Connector運行模式】
BIO、NIO柔逼、APR三種蒋譬。BIO是默認的,修改為NIO只需要修改connector的協(xié)議愉适,例如將協(xié)議Http11Protocol修改為Http11NioProtocol犯助;APR是從操作系統(tǒng)級別來解決異步的IO問題,利用中斷的方式主動處理請求维咸,需要安裝APR和native剂买,協(xié)議修改為Http11AprProtocol。
【061 Tomcat的調(diào)優(yōu)方案】
Tomcat調(diào)優(yōu)可以從JVM虛擬機和Tomcat自身兩個層面進行優(yōu)化:
① JVM方面癌蓖,主要是考慮內(nèi)存大小雷恃,調(diào)整堆空間,Tomcat默認可以使用的內(nèi)存為128MB费坊。應(yīng)用程序需要的內(nèi)存超出堆的最大值時虛擬機就會提示內(nèi)存溢出倒槐。在bin目錄下的catalina.bat或catalina.sh,設(shè)置JAVA_OPTS=-Xms初始化內(nèi)存大小 -Xmx可以使用的最大內(nèi)存附井,一般建議堆的最大值設(shè)置為可用內(nèi)存的最大值的80%讨越,另外[初始化內(nèi)存大小]等于[可以使用的最大內(nèi)存],這樣可以減少平凡分配堆而降低性能永毅。
② Tomcat方面把跨,主要是連接器Connector的優(yōu)化,通過修改minProcessors和maxProcessors的值來控制線程數(shù)沼死,通常Windows是1000個左右着逐,Linux是2000個左右。