之前的兩篇文章探討了兩種HTTP Server的工作原理,本篇講解Java開(kāi)發(fā)中最常使用的一款應(yīng)用web服務(wù)器Tomcat。有過(guò)開(kāi)發(fā)經(jīng)驗(yàn)的人應(yīng)該了解因?yàn)锳pache人灼,Nginx等HTTP Server只能解析靜態(tài)資源坐昙,不能解析Java Web開(kāi)發(fā)中使用的Servlet和JSP,因此需要有一款能夠解析Java語(yǔ)言的服務(wù)器使得Java Web項(xiàng)目能夠正常運(yùn)行溉浙。Tomcat作為Java Web項(xiàng)目的容器將項(xiàng)目部署到其webapps目錄下即可運(yùn)行烫止。
Tomcat工作原理
基于Java的Web 應(yīng)用程序是 servlet、JSP 頁(yè)面戳稽、靜態(tài)頁(yè)面馆蠕、類(lèi)和其他資源的集合,它們可以用標(biāo)準(zhǔn)方式打包惊奇,并運(yùn)行在來(lái)自多個(gè)供應(yīng)商的多個(gè)容器互躬。Web 應(yīng)用程序存在于結(jié)構(gòu)化層次結(jié)構(gòu)的目錄中,該層次結(jié)構(gòu)是由 Java Servlet 規(guī)范定義的颂郎。Web 應(yīng)用程序的根目錄包含直接存儲(chǔ)或存儲(chǔ)在子文件夾中的所有公共資源吼渡,比如圖像、HTML 頁(yè)面等乓序。構(gòu)成:Web應(yīng)用由Web組件(一組Java類(lèi)庫(kù))寺酪、html文件,靜態(tài)資源文件(如圖像)替劈、幫助類(lèi)和庫(kù)組成房维。
Tomcat Server的組成部分
①Server
一個(gè)英文的比較官方的定義
A Server element represents the entire Catalina servlet container. (Singleton)
大致意思就是Server是一個(gè)Servlet容器,有且只有一個(gè)抬纸。Server起管理者的作用咙俩,管理Tomcat的其他組件。
②Service
A Service element represents the combination of one or more Connector components that share a single Engine
Service是這樣一個(gè)集合:它由共享同的一個(gè)Engine一個(gè)或者多個(gè)Connector組成湿故,負(fù)責(zé)處理所有Connector所獲得的客戶(hù)請(qǐng)求阿趁。
③Connector
一個(gè)Connector將在某個(gè)指定端口上偵聽(tīng)客戶(hù)請(qǐng)求,并將獲得的請(qǐng)求交給Engine來(lái)處理坛猪,從Engine處獲得回應(yīng)并返回客戶(hù)脖阵。
Tomcat包含兩類(lèi)Connector,分別是Coyote Http/1.1 Connector墅茉,默認(rèn)監(jiān)聽(tīng)8080端口命黔,直接偵聽(tīng)來(lái)自browser的http請(qǐng)求呜呐。另一類(lèi)是Coyote JK2 Connector,監(jiān)聽(tīng)8009端口悍募,偵聽(tīng)來(lái)自其它WebServer的請(qǐng)求蘑辑。如來(lái)自Apache或者Nginx的請(qǐng)求。
④Engine
The Engine element represents the entire request processing machinery associated with a particular Service
It receives and processes all requests from one or more Connectors
and returns the completed response to the Connector for ultimate transmission back to the client
從上面這段話得知Engine是處理請(qǐng)求并返回響應(yīng)的中樞組件坠宴,且可以關(guān)聯(lián)一個(gè)或多個(gè)Connector洋魂。Engine下可以配置多個(gè)虛擬主機(jī)Virtual Host,每個(gè)虛擬主機(jī)都有一個(gè)域名喜鼓。當(dāng)Engine獲得一個(gè)請(qǐng)求時(shí)副砍,它把該請(qǐng)求匹配到某個(gè)Host上,然后把該請(qǐng)求交給該Host來(lái)處理庄岖。Engine有一個(gè)默認(rèn)虛擬主機(jī)豁翎,當(dāng)請(qǐng)求無(wú)法匹配到任何一個(gè)Host上的時(shí)候,將交給該默認(rèn)Host來(lái)處理隅忿。如果出現(xiàn)匹配不到的情況心剥,則交由localhost處理。
⑤Host
指一個(gè)Virtual Host硼控,虛擬主機(jī)和某個(gè)網(wǎng)絡(luò)域名Domain Name相匹配。每個(gè)虛擬主機(jī)下都可以部署(deploy)一個(gè)或者多個(gè)Web App胳赌,每個(gè)Web App對(duì)應(yīng)于一個(gè)Context牢撼,有一個(gè)Context path。當(dāng)Host獲得一個(gè)請(qǐng)求時(shí)疑苫,將把該請(qǐng)求匹配到某個(gè)Context上熏版,然后把該請(qǐng)求交給該Context來(lái)處理。
⑥Context
一個(gè)Context對(duì)應(yīng)于一個(gè)Web Application捍掺,一個(gè)Web Application由一個(gè)或者多個(gè)Servlet組成撼短。Context在創(chuàng)建的時(shí)候?qū)⒏鶕?jù)配置文件$CATALINA_HOME/conf/web.xml和$WEBAPP_HOME/WEB-INF/web.xml載入Servlet類(lèi)。當(dāng)Context獲得請(qǐng)求時(shí)挺勿,將在自己的映射表(即web.xml中的一眾mapping)中尋找相匹配的Servlet類(lèi)曲横,如果找到,則執(zhí)行該類(lèi)不瓶,獲得請(qǐng)求的回應(yīng)禾嫉,并返回。
Tomcat Server處理一個(gè)http請(qǐng)求的過(guò)程
以http://localhost:8080/mypro/index.jsp的請(qǐng)求過(guò)程為例
①請(qǐng)求被發(fā)送到本機(jī)端口8080蚊丐,被在那里偵聽(tīng)的Coyote HTTP/1.1 Connector獲得熙参。
②Connector把該請(qǐng)求交給它所在的Service的Engine來(lái)處理,并等待來(lái)自Engine的回應(yīng)麦备。
③ Engine獲得請(qǐng)求localhost/mypro/index.jsp孽椰,匹配它所擁有的所有虛擬主機(jī)Host昭娩。
④Engine匹配到名為localhost的Host。
⑤localhost Host獲得請(qǐng)求/mypro/index.jsp黍匾,匹配它所擁有的所有Context栏渺。匹配到路徑為/mypro的Context。
⑥Context獲得請(qǐng)求/index.jsp膀捷,在它的mapping table中尋找對(duì)應(yīng)的servlet迈嘹。Context匹配到URL PATTERN為*.jsp的Servlet。
⑦構(gòu)造HttpServletRequest對(duì)象和HttpServletResponse對(duì)象全庸,作為參數(shù)調(diào)用Servlet的doGet或doPost方法并把執(zhí)行完了之后的HttpServletResponse對(duì)象返回給Host秀仲。
⑧Host把HttpServletResponse對(duì)象返回給Engine。
⑨Engine把HttpServletResponse對(duì)象返回給Connector壶笼。
⑩Connector把HttpServletResponse對(duì)象返回給客戶(hù)browser神僵。
Tomcat的工作流程講到這里,之后將有專(zhuān)門(mén)的文章講解HTTP Server如何與Application Server相結(jié)合使用覆劈。將以Tomcat和Nginx整合使用為例保礼。