iis、apache、tomcat、weblogic、websphere都各屬于哪種服務(wù)器,這些問題困惑了很久,今天終于梳理清楚了:
web服務(wù)器的基本功能就是提供web信息瀏覽服務(wù)。它只需支持http協(xié)議、html文檔格式及url。與客戶端的網(wǎng)絡(luò)瀏覽器配合。因?yàn)閣eb服務(wù)器主要支持的協(xié)議就是http,所以通常情況下http服務(wù)器和web服務(wù)器是相等的(有沒有支持除http之外的協(xié)議的web服務(wù)器,作者沒有考證過),說的是一回事。
應(yīng)用程序服務(wù)器(簡(jiǎn)稱應(yīng)用服務(wù)器),我們先看一下微軟對(duì)它的定義:"我們把應(yīng)用程序服務(wù)器定義為“作為服務(wù)器執(zhí)行共享業(yè)務(wù)應(yīng)用程序的底層的系統(tǒng)軟件”。 就像文件服務(wù)器為很多用戶提供文件一樣,應(yīng)用程序服務(wù)器讓多個(gè)用戶可以同時(shí)使用應(yīng)用程序(通常是客戶創(chuàng)建的應(yīng)用程序)"
通俗的講,web服務(wù)器傳送(serves)頁面使瀏覽器可以瀏覽,然而應(yīng)用程序服務(wù)器提供的是客戶端應(yīng)用程序可以調(diào)用(call)的方法(methods)。確切一點(diǎn),你可以說:web服務(wù)器專門處理http請(qǐng)求(request),但是應(yīng)用程序服務(wù)器是通過很多協(xié)議來為應(yīng)用程序提供(serves)商業(yè)邏輯 (business logic)。
以java ee為例,web服務(wù)器主要是處理靜態(tài)頁面處理和作為 servlet容器,解釋和執(zhí)行servlet/jsp,而應(yīng)用服務(wù)器是運(yùn)行業(yè)務(wù)邏輯的,主要是ejb、 jndi和jmx api等j2ee api方面的,還包含事務(wù)處理、數(shù)據(jù)庫連接等功能,所以在企業(yè)級(jí)應(yīng)用中,應(yīng)用服務(wù)器提供的功能比web服務(wù)器強(qiáng)大的多。
以這樣的定義,iis、apache、tomcat都可以屬于web服務(wù)器,weblogic、websphere都屬于應(yīng)用服務(wù)器。
apache:在web服務(wù)器中,apache是純粹的web服務(wù)器,經(jīng)常與tomcat配對(duì)使用。它對(duì)html頁面具有強(qiáng)大的解釋能力,但是不能解釋嵌入頁面內(nèi)的服務(wù)器端腳本代碼(jsp/servlet)。
tomcat:早期的tomcat是一個(gè)嵌入apache內(nèi)的jsp/servlet解釋引擎apache tomcat就相當(dāng)于iis asp。后來的tomcat已不再嵌入apache內(nèi),tomcat進(jìn)程獨(dú)立于apache進(jìn)程運(yùn)行。 而且,tomcat已經(jīng)是一個(gè)獨(dú)立的servlet和jsp容器,業(yè)務(wù)邏輯層代碼和界面交互層代碼可以分離了。因此,有人把tomcat叫做輕量級(jí)應(yīng)用服務(wù)器。
iis:微軟早期的iis,就是一個(gè)純粹的web服務(wù)器。后來,它嵌入了asp引擎,可以解釋vbscript和jscript服務(wù)器端代碼了,這時(shí),它就可以兼作應(yīng)用服務(wù)器。當(dāng)然,它與j2ee應(yīng)用服務(wù)器根本無法相比,但是,從功能上說,從原理上說,它勉強(qiáng)可以稱之為應(yīng)用服務(wù)器。確切地說,它是兼有一點(diǎn)應(yīng)用服務(wù)器功能的web服務(wù)器。
綜上:apache是純粹的web服務(wù)器,而tomcat和iis因?yàn)榫哂辛私忉寛?zhí)行服務(wù)器端代碼的能力,可以稱作為輕量級(jí)應(yīng)用服務(wù)器或帶有服務(wù)器功能的web服務(wù)器。weblogic、websphere因?yàn)槟芴峁?qiáng)大的j2ee功能,毫無疑問是絕對(duì)的應(yīng)用服務(wù)器。對(duì)于處于中間位置的tomcat,它可以配合純web服務(wù)器apache一起使用,也可以作為應(yīng)用服務(wù)器的輔助與應(yīng)用服務(wù)器一起部署:
一、tomcat與應(yīng)用服務(wù)器
到目前為止,tomcat一直被認(rèn)為是servlet/jsp api的執(zhí)行器,也就所謂的servlet容器。然而,tomcat并不僅僅如此,它還提供了jndi和jmx api的實(shí)現(xiàn)機(jī)制。盡管如此,tomcat仍然還不能算是應(yīng)用服務(wù)器,因?yàn)樗惶峁┐蠖鄶?shù)j2ee api的支持。
很有意思的是,目前許多的應(yīng)用服務(wù)器通常把tomcat作為它們servlet和jsp api的容器。由于tomcat允許開發(fā)者只需通過加入一行致謝,就可以把tomcat嵌入到它們的應(yīng)用中。遺憾的是,許多商業(yè)應(yīng)用服務(wù)器并沒有遵守此規(guī)則。
對(duì)于開發(fā)者來說,如果是為了尋找利用servlet、jsp、jndi和jmx技術(shù)來生成java web應(yīng)用的話,選擇tomcat是一個(gè)優(yōu)秀的解決方案;但是為了尋找支持其他的j2ee api,那么尋找一個(gè)應(yīng)用服務(wù)器或者把tomcat作為應(yīng)用服務(wù)器的輔助,將是一個(gè)不錯(cuò)的解決方案;第三種方式是找到獨(dú)立的j2ee api實(shí)現(xiàn),然后把它們跟tomcat結(jié)合起來使用。雖然整合會(huì)帶來相關(guān)的問題,但是這種方式是最為有效的。。
二、tomcat與web服務(wù)器
tomcat是提供一個(gè)支持servlet和jsp運(yùn)行的容器。servlet和jsp能根據(jù)實(shí)時(shí)需要,產(chǎn)生動(dòng)態(tài)網(wǎng)頁內(nèi)容。而對(duì)于web服務(wù)器來說, apache僅僅支持靜態(tài)網(wǎng)頁,對(duì)于支持動(dòng)態(tài)網(wǎng)頁就會(huì)顯得無能為力;tomcat則既能為動(dòng)態(tài)網(wǎng)頁服務(wù),同時(shí)也能為靜態(tài)網(wǎng)頁提供支持。盡管它沒有通常的web服務(wù)器快、功能也不如web服務(wù)器豐富,但是tomcat逐漸為支持靜態(tài)內(nèi)容不斷擴(kuò)充。大多數(shù)的web服務(wù)器都是用底層語言編寫如c,利用了相應(yīng)平臺(tái)的特征,因此用純java編寫的tomcat執(zhí)行速度不可能與它們相提并論。
一般來說,大的站點(diǎn)都是將tomcat與apache的結(jié)合,apache負(fù)責(zé)接受所有來自客戶端的http請(qǐng)求,然后將servlets和jsp的請(qǐng)求轉(zhuǎn)發(fā)給tomcat來處理。tomcat完成處理后,將響應(yīng)傳回給apache,最后apache將響應(yīng)返回給客戶端。而且為了提高性能,可以一臺(tái)apache連接多臺(tái)tomcat實(shí)現(xiàn)負(fù)載平衡。
下面讓我們來細(xì)細(xì)道來:
web服務(wù)器(web server)
web服務(wù)器可以解析(handles)http協(xié)議。當(dāng)web服務(wù)器接收到一個(gè)http請(qǐng)求(request),會(huì)返回一個(gè)http響應(yīng) (response),例如送回一個(gè)html頁面。為了處理一個(gè)請(qǐng)求(request),web服務(wù)器可以響應(yīng)(response)一個(gè)靜態(tài)頁面或圖片,進(jìn)行頁面跳轉(zhuǎn)(redirect),或者把動(dòng)態(tài)響應(yīng)(dynamic response)的產(chǎn)生委托(delegate)給一些其它的程序例如cgi腳本,jsp(javaserver pages)腳本,servlets,asp(active server pages)腳本,服務(wù)器端(server-side)javascript,或者一些其它的服務(wù)器端(server-side)技術(shù)。無論它們(譯者注:腳本)的目的如何,這些服務(wù)器端(server-side)的程序通常產(chǎn)生一個(gè)html的響應(yīng)(response)來讓瀏覽器可以瀏覽。
要知道,web服務(wù)器的代理模型(delegation model)非常簡(jiǎn)單。當(dāng)一個(gè)請(qǐng)求(request)被送到web服務(wù)器里來時(shí),它只單純的把請(qǐng)求(request)傳遞給可以很好的處理請(qǐng)求 (request)的程序(譯者注:服務(wù)器端腳本)。web服務(wù)器僅僅提供一個(gè)可以執(zhí)行服務(wù)器端(server-side)程序和返回(程序所產(chǎn)生的)響應(yīng)(response)的環(huán)境,而不會(huì)超出職能范圍。服務(wù)器端(server-side)程序通常具有事務(wù)處理(transaction processing),數(shù)據(jù)庫連接(database connectivity)和消息(messaging)等功能。
雖然web服務(wù)器不支持事務(wù)處理或數(shù)據(jù)庫連接池,但它可以配置(employ)各種策略(strategies)來實(shí)現(xiàn)容錯(cuò)性(fault tolerance)和可擴(kuò)展性(scalability),例如負(fù)載平衡(load balancing),緩沖(caching)。集群特征(clustering—features)經(jīng)常被誤認(rèn)為僅僅是應(yīng)用程序服務(wù)器專有的特征。
應(yīng)用程序服務(wù)器(the application server)
根據(jù)我們的定義,作為應(yīng)用程序服務(wù)器,它通過各種協(xié)議,可以包括http,把商業(yè)邏輯暴露給(expose)客戶端應(yīng)用程序。web服務(wù)器主要是處理向?yàn)g覽器發(fā)送html以供瀏覽,而應(yīng)用程序服務(wù)器提供訪問商業(yè)邏輯的途徑以供客戶端應(yīng)用程序使用。應(yīng)用程序使用此商業(yè)邏輯就象你調(diào)用對(duì)象的一個(gè)方法 (或過程語言中的一個(gè)函數(shù))一樣。
應(yīng)用程序服務(wù)器的客戶端(包含有圖形用戶界面(gui)的)可能會(huì)運(yùn)行在一臺(tái)pc、一個(gè)web服務(wù)器或者甚至是其它的應(yīng)用程序服務(wù)器上。在應(yīng)用程序服務(wù)器與其客戶端之間來回穿梭(traveling)的信息不僅僅局限于簡(jiǎn)單的顯示標(biāo)記。相反,這種信息就是程序邏輯(program logic)。正是由于這種邏輯取得了(takes)數(shù)據(jù)和方法調(diào)用(calls)的形式而不是靜態(tài)html,所以客戶端才可以隨心所欲的使用這種被暴露的商業(yè)邏輯。
在大多數(shù)情形下,應(yīng)用程序服務(wù)器是通過組件 (component) 的應(yīng)用程序接口(api)把商業(yè)邏輯暴露(expose)(給客戶端應(yīng)用程序)的,例如基于j2ee(java 2 platform, enterprise edition)應(yīng)用程序服務(wù)器的ejb(enterprise javabean)組件模型。此外,應(yīng)用程序服務(wù)器可以管理自己的資源,例如看大門的工作(gate-keeping duties)包括安全(security),事務(wù)處理(transaction processing),資源池(resource pooling),和消息(messaging)。就象web服務(wù)器一樣,應(yīng)用程序服務(wù)器配置了多種可擴(kuò)展(sc