2023-07-08 分類: 網(wǎng)站建設(shè)
導(dǎo)讀:WEB服務(wù)器、應(yīng)用程序服務(wù)器、HTTP服務(wù)器有何區(qū)別?IIS、Apache、Tomcat、Weblogic、WebSphere都各屬于哪種服務(wù)器,這些問題困惑了很久,今天終于梳理清楚了,:創(chuàng)新互聯(lián)服務(wù)器租用就一一為大家講解這個(gè)問題,以下是內(nèi)容詳情。
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ù)器(簡稱應(yīng)用服務(wù)器),我們先看一下微軟對它的定義:”我們把應(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請求(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è)級應(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配對使用。它對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叫做輕量級應(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ù)器端代碼的能力,可以稱作為輕量級應(yīng)用服務(wù)器或帶有服務(wù)器功能的Web服務(wù)器。Weblogic、WebSphere因?yàn)槟芴峁?qiáng)大的J2EE功能,毫無疑問是絕對的應(yīng)用服務(wù)器。對于處于中間位置的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ī)則。
對于開發(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é)合起來使用。雖然整合會帶來相關(guān)的問題,但是這種方式是為有效的。。
二、Tomcat與Web服務(wù)器
Tomcat是提供一個(gè)支持Servlet和JSP運(yùn)行的容器。Servlet和JSP能根據(jù)實(shí)時(shí)需要,產(chǎn)生動態(tài)網(wǎng)頁內(nèi)容。而對于Web服務(wù)器來說, Apache僅僅支持靜態(tài)網(wǎng)頁,對于支持動態(tài)網(wǎng)頁就會顯得無能為力;Tomcat則既能為動態(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)平臺的特征,因此用純Java編寫的Tomcat執(zhí)行速度不可能與它們相提并論。
一般來說,大的站點(diǎn)都是將Tomcat與Apache的結(jié)合,Apache負(fù)責(zé)接受所有來自客戶端的HTTP請求,然后將Servlets和JSP的請求轉(zhuǎn)發(fā)給Tomcat來處理。Tomcat完成處理后,將響應(yīng)傳回給Apache,最后Apache將響應(yīng)返回給客戶端。
而且為了提高性能,可以一臺apache連接多臺tomcat實(shí)現(xiàn)負(fù)載平衡。
關(guān)于WEB服務(wù)器、應(yīng)用程序服務(wù)器的更詳細(xì)區(qū)別可以參考下面這篇文章:
通俗的講,Web服務(wù)器傳送(serves)頁面使瀏覽器可以瀏覽,然而應(yīng)用程序服務(wù)器提供的是客戶端應(yīng)用程序可以調(diào)用(call)的方法(methods)。確切一點(diǎn),你可以說:Web服務(wù)器專門處理HTTP請求(request),但是應(yīng)用程序服務(wù)器是通過很多協(xié)議來為應(yīng)用程序提供(serves)商業(yè)邏輯 (business logic)。
下面讓我們來細(xì)細(xì)道來:
Web服務(wù)器(Web Server)
Web服務(wù)器可以解析(handles)HTTP協(xié)議。當(dāng)Web服務(wù)器接收到一個(gè)HTTP請求(request),會返回一個(gè)HTTP響應(yīng) (response),例如送回一個(gè)HTML頁面。為了處理一個(gè)請求(request),Web服務(wù)器可以響應(yīng)(response)一個(gè)靜態(tài)頁面或圖片,進(jìn)行頁面跳轉(zhuǎn)(redirect),或者把動態(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)非常簡單。當(dāng)一個(gè)請求(request)被送到Web服務(wù)器里來時(shí),它只單純的把請求(request)傳遞給可以很好的處理請求 (request)的程序(譯者注:服務(wù)器端腳本)。Web服務(wù)器僅僅提供一個(gè)可以執(zhí)行服務(wù)器端(server-side)程序和返回(程序所產(chǎn)生的)響應(yīng)(response)的環(huán)境,而不會超出職能范圍。服務(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)用對象的一個(gè)方法 (或過程語言中的一個(gè)函數(shù))一樣。
應(yīng)用程序服務(wù)器的客戶端(包含有圖形用戶界面(GUI)的)可能會運(yùn)行在一臺PC、一個(gè)Web服務(wù)器或者甚至是其它的應(yīng)用程序服務(wù)器上。在應(yīng)用程序服務(wù)器與其客戶端之間來回穿梭(traveling)的信息不僅僅局限于簡單的顯示標(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ò)展(scalability)和容錯(cuò)(fault tolerance)技術(shù)。
一個(gè)例子
例如,設(shè)想一個(gè)在線商店(網(wǎng)站)提供實(shí)時(shí)定價(jià)(real-time pricing)和有效性(availability)信息。這個(gè)站點(diǎn)(site)很可能會提供一個(gè)表單(form)讓你來選擇產(chǎn)品。當(dāng)你提交查詢 (query)后,網(wǎng)站會進(jìn)行查找(lookup)并把結(jié)果內(nèi)嵌在HTML頁面中返回。網(wǎng)站可以有很多種方式來實(shí)現(xiàn)這種功能。我要介紹一個(gè)不使用應(yīng)用程序服務(wù)器 的情景和一個(gè)使用應(yīng)用程序服務(wù)器的情景。觀察一下這兩中情景的不同會有助于你了解應(yīng)用程序服務(wù)器的功能。
情景1:不帶應(yīng)用程序服務(wù)器的Web服務(wù)器
在此種情景下,一個(gè)Web服務(wù)器獨(dú)立提供在線商店的功能。Web服務(wù)器獲得你的請求(request),然后發(fā)送給服務(wù)器端(server- side)可以處理請求(request)的程序。此程序從數(shù)據(jù)庫或文本文件(flat file,譯者注:flat file是指沒有特殊格式的非二進(jìn)制的文件,如properties和XML文件等)中查找定價(jià)信息。一旦找到,服務(wù)器端(server-side)程序把結(jié)果信息表示成(formulate)HTML形式,最后Web服務(wù)器把會它發(fā)送到你的Web瀏覽器。
簡而言之,Web服務(wù)器只是簡單的通過響應(yīng)(response)HTML頁面來處理HTTP請求(request)。
情景2:帶應(yīng)用程序服務(wù)器的Web服務(wù)器
情景2和情景1相同的是Web服務(wù)器還是把響應(yīng)(response)的產(chǎn)生委托(delegates)給腳本(譯者注:服務(wù)器端 (server-side)程序)。然而,你可以把查找定價(jià)的商業(yè)邏輯(business logic)放到應(yīng)用程序服務(wù)器上。由于這種變化,此腳本只是簡單的調(diào)用應(yīng)用程序服務(wù)器的查找服務(wù)(lookup service),而不是已經(jīng)知道如何查找數(shù)據(jù)然后表示為(formulate)一個(gè)響應(yīng)(response)。這時(shí)當(dāng)該腳本程序產(chǎn)生HTML響應(yīng)(response)時(shí)就可以使用該服務(wù)的返回結(jié)果了。
在此情景中,應(yīng)用程序服務(wù)器提供(serves)了用于查詢產(chǎn)品的定價(jià)信息的商業(yè)邏輯。(服務(wù)器的)這種功能(functionality)沒有指出有關(guān)顯示和客戶端如何使用此信息的細(xì)節(jié),相反客戶端和應(yīng)用程序服務(wù)器只是來回傳送數(shù)據(jù)。當(dāng)有客戶端調(diào)用應(yīng)用程序服務(wù)器的查找服務(wù)(lookup service)時(shí),此服務(wù)只是簡單的查找并返回結(jié)果給客戶端。
通過從響應(yīng)產(chǎn)生(response-generating)HTML的代碼中分離出來,在應(yīng)用程序之中該定價(jià)(查找)邏輯的可重用性更強(qiáng)了。其他的客戶端,例如收款機(jī),也可以調(diào)用同樣的服務(wù)(service)來作為一個(gè)店員給客戶結(jié)帳。相反,在情景1中的定價(jià)查找服務(wù)是不可重用的因?yàn)樾畔?nèi)嵌在 HTML頁中了。
總而言之,在情景2的模型中,在Web服務(wù)器通過回應(yīng)HTML頁面來處理HTTP請求(request),而應(yīng)用程序服務(wù)器則是通過處理定價(jià)和有效性(availability)請求(request)來提供應(yīng)用程序邏輯的。
警告(Caveats)
現(xiàn)在,XML Web Services已經(jīng)使應(yīng)用程序服務(wù)器和Web服務(wù)器的界線混淆了。通過傳送一個(gè)XML有效載荷(payload)給服務(wù)器,Web服務(wù)器現(xiàn)在可以處理數(shù)據(jù)和響應(yīng)(response)的能力與以前的應(yīng)用程序服務(wù)器同樣多了。
另外,現(xiàn)在大多數(shù)應(yīng)用程序服務(wù)器也包含了Web服務(wù)器,這就意味著可以把Web服務(wù)器當(dāng)作是應(yīng)用程序服務(wù)器的一個(gè)子集(subset)。雖然應(yīng)用程序服務(wù)器包含了Web服務(wù)器的功能,但是開發(fā)者很少把應(yīng)用程序服務(wù)器部署(deploy)成這種功能(capacity)(譯者注:這種功能是指既有應(yīng)用程序服務(wù)器的功能又有Web服務(wù)器的功能)。相反,如果需要,他們通常會把Web服務(wù)器獨(dú)立配置,和應(yīng)用程序服務(wù)器一前一后。這種功能的分離有助于提高性能(簡單的Web請求(request)就不會影響應(yīng)用程序服務(wù)器了),分開配置(專門的Web服務(wù)器,集群(clustering)等等),而且給最佳產(chǎn)品的選取留有余地。
WEB服務(wù)器、應(yīng)用程序服務(wù)器、HTTP服務(wù)器有何區(qū)別?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ù)器(簡稱應(yīng)用服務(wù)器),我們先看一下微軟對它的定義:”我們把應(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請求(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è)級應(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配對使用。它對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叫做輕量級應(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ù)器端代碼的能力,可以稱作為輕量級應(yīng)用服務(wù)器或帶有服務(wù)器功能的Web服務(wù)器。Weblogic、WebSphere因?yàn)槟芴峁?qiáng)大的J2EE功能,毫無疑問是絕對的應(yīng)用服務(wù)器。對于處于中間位置的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ī)則。
對于開發(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é)合起來使用。雖然整合會帶來相關(guān)的問題,但是這種方式是為有效的。。
二、Tomcat與Web服務(wù)器
Tomcat是提供一個(gè)支持Servlet和JSP運(yùn)行的容器。Servlet和JSP能根據(jù)實(shí)時(shí)需要,產(chǎn)生動態(tài)網(wǎng)頁內(nèi)容。而對于Web服務(wù)器來說, Apache僅僅支持靜態(tài)網(wǎng)頁,對于支持動態(tài)網(wǎng)頁就會顯得無能為力;Tomcat則既能為動態(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)平臺的特征,因此用純Java編寫的Tomcat執(zhí)行速度不可能與它們相提并論。
一般來說,大的站點(diǎn)都是將Tomcat與Apache的結(jié)合,Apache負(fù)責(zé)接受所有來自客戶端的HTTP請求,然后將Servlets和JSP的請求轉(zhuǎn)發(fā)給Tomcat來處理。Tomcat完成處理后,將響應(yīng)傳回給Apache,最后Apache將響應(yīng)返回給客戶端。
而且為了提高性能,可以一臺apache連接多臺tomcat實(shí)現(xiàn)負(fù)載平衡。
關(guān)于WEB服務(wù)器、應(yīng)用程序服務(wù)器的更詳細(xì)區(qū)別可以參考下面這篇文章:
通俗的講,Web服務(wù)器傳送(serves)頁面使瀏覽器可以瀏覽,然而應(yīng)用程序服務(wù)器提供的是客戶端應(yīng)用程序可以調(diào)用(call)的方法(methods)。確切一點(diǎn),你可以說:Web服務(wù)器專門處理HTTP請求(request),但是應(yīng)用程序服務(wù)器是通過很多協(xié)議來為應(yīng)用程序提供(serves)商業(yè)邏輯 (business logic)。
下面讓我們來細(xì)細(xì)道來:
Web服務(wù)器(Web Server)
Web服務(wù)器可以解析(handles)HTTP協(xié)議。當(dāng)Web服務(wù)器接收到一個(gè)HTTP請求(request),會返回一個(gè)HTTP響應(yīng) (response),例如送回一個(gè)HTML頁面。為了處理一個(gè)請求(request),Web服務(wù)器可以響應(yīng)(response)一個(gè)靜態(tài)頁面或圖片,進(jìn)行頁面跳轉(zhuǎn)(redirect),或者把動態(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)非常簡單。當(dāng)一個(gè)請求(request)被送到Web服務(wù)器里來時(shí),它只單純的把請求(request)傳遞給可以很好的處理請求 (request)的程序(譯者注:服務(wù)器端腳本)。Web服務(wù)器僅僅提供一個(gè)可以執(zhí)行服務(wù)器端(server-side)程序和返回(程序所產(chǎn)生的)響應(yīng)(response)的環(huán)境,而不會超出職能范圍。服務(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)用對象的一個(gè)方法 (或過程語言中的一個(gè)函數(shù))一樣。
應(yīng)用程序服務(wù)器的客戶端(包含有圖形用戶界面(GUI)的)可能會運(yùn)行在一臺PC、一個(gè)Web服務(wù)器或者甚至是其它的應(yīng)用程序服務(wù)器上。在應(yīng)用程序服務(wù)器與其客戶端之間來回穿梭(traveling)的信息不僅僅局限于簡單的顯示標(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ò)展(scalability)和容錯(cuò)(fault tolerance)技術(shù)。
一個(gè)例子
例如,設(shè)想一個(gè)在線商店(網(wǎng)站)提供實(shí)時(shí)定價(jià)(real-time pricing)和有效性(availability)信息。這個(gè)站點(diǎn)(site)很可能會提供一個(gè)表單(form)讓你來選擇產(chǎn)品。當(dāng)你提交查詢 (query)后,網(wǎng)站會進(jìn)行查找(lookup)并把結(jié)果內(nèi)嵌在HTML頁面中返回。網(wǎng)站可以有很多種方式來實(shí)現(xiàn)這種功能。我要介紹一個(gè)不使用應(yīng)用程序服務(wù)器 的情景和一個(gè)使用應(yīng)用程序服務(wù)器的情景。觀察一下這兩中情景的不同會有助于你了解應(yīng)用程序服務(wù)器的功能。
情景1:不帶應(yīng)用程序服務(wù)器的Web服務(wù)器
在此種情景下,一個(gè)Web服務(wù)器獨(dú)立提供在線商店的功能。Web服務(wù)器獲得你的請求(request),然后發(fā)送給服務(wù)器端(server- side)可以處理請求(request)的程序。此程序從數(shù)據(jù)庫或文本文件(flat file,譯者注:flat file是指沒有特殊格式的非二進(jìn)制的文件,如properties和XML文件等)中查找定價(jià)信息。一旦找到,服務(wù)器端(server-side)程序把結(jié)果信息表示成(formulate)HTML形式,最后Web服務(wù)器把會它發(fā)送到你的Web瀏覽器。
簡而言之,Web服務(wù)器只是簡單的通過響應(yīng)(response)HTML頁面來處理HTTP請求(request)。
情景2:帶應(yīng)用程序服務(wù)器的Web服務(wù)器
情景2和情景1相同的是Web服務(wù)器還是把響應(yīng)(response)的產(chǎn)生委托(delegates)給腳本(譯者注:服務(wù)器端 (server-side)程序)。然而,你可以把查找定價(jià)的商業(yè)邏輯(business logic)放到應(yīng)用程序服務(wù)器上。由于這種變化,此腳本只是簡單的調(diào)用應(yīng)用程序服務(wù)器的查找服務(wù)(lookup service),而不是已經(jīng)知道如何查找數(shù)據(jù)然后表示為(formulate)一個(gè)響應(yīng)(response)。這時(shí)當(dāng)該腳本程序產(chǎn)生HTML響應(yīng)(response)時(shí)就可以使用該服務(wù)的返回結(jié)果了。
在此情景中,應(yīng)用程序服務(wù)器提供(serves)了用于查詢產(chǎn)品的定價(jià)信息的商業(yè)邏輯。(服務(wù)器的)這種功能(functionality)沒有指出有關(guān)顯示和客戶端如何使用此信息的細(xì)節(jié),相反客戶端和應(yīng)用程序服務(wù)器只是來回傳送數(shù)據(jù)。當(dāng)有客戶端調(diào)用應(yīng)用程序服務(wù)器的查找服務(wù)(lookup service)時(shí),此服務(wù)只是簡單的查找并返回結(jié)果給客戶端。
通過從響應(yīng)產(chǎn)生(response-generating)HTML的代碼中分離出來,在應(yīng)用程序之中該定價(jià)(查找)邏輯的可重用性更強(qiáng)了。其他的客戶端,例如收款機(jī),也可以調(diào)用同樣的服務(wù)(service)來作為一個(gè)店員給客戶結(jié)帳。相反,在情景1中的定價(jià)查找服務(wù)是不可重用的因?yàn)樾畔?nèi)嵌在 HTML頁中了。
總而言之,在情景2的模型中,在Web服務(wù)器通過回應(yīng)HTML頁面來處理HTTP請求(request),而應(yīng)用程序服務(wù)器則是通過處理定價(jià)和有效性(availability)請求(request)來提供應(yīng)用程序邏輯的。
警告(Caveats)
現(xiàn)在,XML Web Services已經(jīng)使應(yīng)用程序服務(wù)器和Web服務(wù)器的界線混淆了。通過傳送一個(gè)XML有效載荷(payload)給服務(wù)器,Web服務(wù)器現(xiàn)在可以處理數(shù)據(jù)和響應(yīng)(response)的能力與以前的應(yīng)用程序服務(wù)器同樣多了。
另外,現(xiàn)在大多數(shù)應(yīng)用程序服務(wù)器也包含了Web服務(wù)器,這就意味著可以把Web服務(wù)器當(dāng)作是應(yīng)用程序服務(wù)器的一個(gè)子集(subset)。雖然應(yīng)用程序服務(wù)器包含了Web服務(wù)器的功能,但是開發(fā)者很少把應(yīng)用程序服務(wù)器部署(deploy)成這種功能(capacity)(譯者注:這種功能是指既有應(yīng)用程序服務(wù)器的功能又有Web服務(wù)器的功能)。相反,如果需要,他們通常會把Web服務(wù)器獨(dú)立配置,和應(yīng)用程序服務(wù)器一前一后。這種功能的分離有助于提高性能(簡單的Web請求(request)就不會影響應(yīng)用程序服務(wù)器了),分開配置(專門的Web服務(wù)器,集群(clustering)等等),而且給最佳產(chǎn)品的選取留有余地。
成都創(chuàng)新互聯(lián)科技有限公司(以下簡稱”創(chuàng)新互聯(lián)”),創(chuàng)新互聯(lián)成立于2013年,是國內(nèi)互聯(lián)網(wǎng)應(yīng)用服務(wù)提供商之一。多年來,創(chuàng)新互聯(lián)致力于為企業(yè)客戶提供完整的互聯(lián)網(wǎng)應(yīng)用服務(wù),一直專注于增值電信業(yè)務(wù),提供包括服務(wù)器托管、服務(wù)器租用、機(jī)柜租用、帶寬租用、云服務(wù)器、云計(jì)算服務(wù)等方面的專業(yè)服務(wù)。與全國多地運(yùn)營商長期具有良好的合作關(guān)系,全國30多個(gè)數(shù)據(jù)中心資源,阿里云、百度云、騰訊云服務(wù)中心。在四川、成都、重慶、綿陽均有本地服務(wù)團(tuán)隊(duì)。咨詢電話135-1821-9792。官網(wǎng)地址www.rwnh.cn
以上就是“服務(wù)器租用介紹(WEB服務(wù)器、應(yīng)用程序服務(wù)器和HTTP服務(wù)器的區(qū)別)”的全部內(nèi)容,點(diǎn)擊IDC資訊中心了解更多文章,,如果大家想咨詢服務(wù)器托管、服務(wù)器租用、機(jī)柜租用、帶寬租用、云服務(wù)器等相關(guān)價(jià)格,敬請關(guān)注我們創(chuàng)新互聯(lián)官網(wǎng)(www.rwnh.cn),或者點(diǎn)擊右側(cè)在線客服進(jìn)行咨詢。
文章題目:服務(wù)器租用介紹(WEB服務(wù)器、應(yīng)用程序服務(wù)器和HTTP服務(wù)器的區(qū)別)
網(wǎng)頁鏈接:http://www.rwnh.cn/news/271236.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制網(wǎng)站、電子商務(wù)、網(wǎng)站內(nèi)鏈、Google、面包屑導(dǎo)航、網(wǎng)頁設(shè)計(jì)公司
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容