1. 程式人生 > >web 伺服器有哪些

web 伺服器有哪些

<1>什麼是web伺服器

"網路服務"(Web Service)的本質,就是通過網路呼叫其他網站的資源。

Web Service架構和雲

如果一個軟體的主要部分採用了"網路服務",即它把儲存或計算環節"外包"給其他網站了,那麼我們就說這個軟體屬於Web Service架構。

Web Service架構的基本思想,就是儘量把非核心功能交給其他人去做,自己全力開發核心功能。比如,如果你要開發一個相簿軟體,完全可以使用Flickr的網路服務,把相片都儲存到它上面,你只要全力做好相簿本身就可以了。總體上看,凡是不屬於你核心競爭力的功能,都應該把它"外包"出去。

最近很紅的"雲端計算"(cloud computing)或者"雲服務"(cloud services),實際上就是Web Service的同義詞,不過更形象一些罷了。它們不說你把事情交給其他計算機去做,而說你把事情交給"雲"去做。

Web Service的優勢

除了本地服務的缺點以外,Web Service還有以下的優越性:

* 平臺無關。不管你使用什麼平臺,都可以使用Web service。

* 程式語言無關。只要遵守相關協議,就可以使用任意程式語言,向其他網站要求Web service。這大大增加了web service的適用性,降低了對程式設計師的要求。

* 對於Web service提供者來說,部署、升級和維護Web service都非常單純,不需要考慮客戶端相容問題,而且一次性就能完成。

* 對於Web service使用者來說,可以輕易實現多種資料、多種服務的聚合(mashup),因此能夠做出一些以前根本無法想像的事情。

Web service的發展趨勢

根據我的觀察,目前Web service有這樣幾種發展趨勢。

* 在使用方式上,RPC和soap的使用在減少,Restful架構佔到了主導地位。

* 在資料格式上,XML格式的使用在減少,json等輕量級格式的使用在增多。

* 在設計架構上,越來越多的第三方軟體讓使用者在客戶端(即瀏覽器),直接與雲端對話,不再使用第三方的伺服器進行中轉或處理資料。

本地服務的缺陷

"網路服務"是未來軟體開發和使用的趨勢,本地服務將用得越來越少,主要因為以下三個原因:

* 本地資源不足。很多資料和資料,本地得不到,只有向其他網站要。

* 成本因素。本地提供服務,往往是不經濟的,使用專業網站的服務更便宜。這裡面涉及硬體和人員兩部分,即使你買得起硬體,專門找一個人管理系統,也是很麻煩的事。

* 可移植性差。如果你想把本機的服務,移植到其他機器上,往往很困難,尤其是在跨平臺的情況下。

對本地服務,除非是大型區域網或者說ejb這類區域網協議訪問,不然的話沒啥意義

現在市面上有面向過程、方面、模組化程式設計,當然最多的是應該是面向物件,

與其說物件程式設計,不如說是類程式設計,軟體即服務,若軟體不能提供功能(介面方法),

也就失去原本意義,它的靈活性,獨立,跨平臺、跨語言

<2>web伺服器有哪些

WEB伺服器也可以稱為網站伺服器,可以用來放置網站檔案,供使用者瀏覽。那麼常見的WEB伺服器有哪些呢?

web伺服器有哪些

①Apache

Apache是世界使用排名的Web伺服器軟體。它幾乎可以執行在所有的計算機平臺上。由於Apache是開源免費的,因此有很多人蔘與到新功能的開發設計,不斷對其進行完善。  Apache的特點是簡單、速度快、效能穩定,並可做代理伺服器來使用。

②IIS

IIS(Internet資訊服務)英文Internet Information  Server的縮寫。它是微軟公司主推的伺服器。IIS的特點具有:安全性,強大,靈活。

③Nginx

Nginx不僅是一個小巧且高效的HTTP伺服器,也可以做一個高效的負載均衡反向代理,通過它接受使用者的請求並分發到多個Mongrel程序可以極大提高Rails應用的併發能力。

④Tomcat

Tomcat是Apache 軟體基金會(Apache Software Foundation)的Jakarta  專案中的一個核心專案,由Apache、Sun 和其他一些公司及個人共同開發而成。Tomcat 技術先進、效能穩定,而且免費,因而深受Java  愛好者的喜愛並得到了部分軟體開發商的認可,成為目前比較流行的Web 應用伺服器。

⑤Lighttpd

Lighttpd是由德國人 Jan Kneschke 領導開發的,基於BSD許可的開源WEB伺服器軟體,其根本的目的是提供一個專門針對高效能網站,安全、快速、相容性好並且靈活的web  server環境。具有非常低的記憶體開銷,CPU佔用率低,效能好,以及豐富的模組等特點。支援FastCGI, CGI, Auth, 輸出壓縮(output  compress), URL重寫, Alias等重要功能。

⑥Zeus

Zeus是一個運行於Unix下的非常的Web 伺服器,據說效能超過Apache,是效率的Web 伺服器之一。

<3>概念

webserver 基本由這些組成

  • 繫結TCP埠,監聽客戶端(瀏覽器)請求
  • 處理客戶端(瀏覽器)請求
  • 響應客戶端(瀏覽器)請求

Web伺服器只負責處理HTTP協議,只能傳送靜態頁面的內容。而JSP,ASP,PHP等動態內容需要通過CGI、FastCGI、ISAPI等介面交給其他程式去處理。這個其他程式就是應用伺服器。 比如Web伺服器包括Nginx,Apache,IIS等。而應用伺服器包括WebLogic,JBoss等。應用伺服器一般也支援HTTP協議,因此界限沒這麼清晰。但是應用伺服器的HTTP協議部分僅僅是支援,一般不會做特別優化,所以很少有見Tomcat直接暴露給外面,而是和Nginx、Apache等配合,只讓Tomcat處理JSP和Servlet部分

<4>web框架和web服務的區別

web伺服器(web server)的主要作用是,接收客戶端請求,而web框架(web framework)則是處理web伺服器收到的請求,並生成HTML內容,將生成的內容傳遞給web伺服器,再由web伺服器返回給客戶端。

伺服器和客戶端之間的連線靠web伺服器來維持,web伺服器接收到請求後,將請求以及相關的引數傳遞給web框架,由框架負責生成內容,並將生成的內容傳遞給web伺服器。所以web伺服器的職責是接受並返回請求,web伺服器的職責是內容生成。

對於Django這類的MVC 框架來說,面臨的主要挑戰是:易開發;對請求物件的完全訪問;保持某種狀態的能力;最重要的是能有寫出業務級邏輯的方式。

而對於 apache, tomcat, nginx這類web 伺服器來說,面臨的主要挑戰是並行;和數以千計的使用者同時保持連線(高併發);能夠在一定時間內傳送大量資料(吞吐量)。

雖然Django這類的框架自帶有web伺服器,但是在面對以上挑戰(高併發,吞吐量)時,效能太雞肋,所以需要專門的web伺服器。

<5>原理

web程式都執行在 TCP/IP 協議上,程式之間使用 socket(套接字) 進行通訊,它能夠讓計算機之間的通訊就像寫檔案和讀檔案一樣簡單。 一個 tcp socket 由一個IP地址和埠號組成。

IP地址是一個32位的二進位制數,通常被分割為4個“8位二進位制數”,寫成10進位制的形式就是我們常見的 174.136.14.108。我們通過IP地址來標識所連線的主機。

埠號是一個範圍在0-65535之間的數字,一臺主機上可能同時有多個sockets,因此需要埠號進行標識。埠號0-1023 是保留給作業系統使用的,我們可以使用剩下的埠號。

超文字傳輸協議(HTTP)描述了一種程式之間交換資料的方法,它非常簡單易用,在一個socket連線上,客戶端首先發送請求說明它需要什麼,然後伺服器傳送響應,並在響應中包含客戶端的資料。響應資料也許是從本地磁碟上覆制來的,也許是程式動態生成的。傳輸過程如圖:

HTTP請求就是一段文字,任何程式都能生成一個http請求,就像生成文字一樣簡單。這段文字需要包含以下這些部分:

  • HTTP method:HTTP請求方法。最常用的就是 GET(抓取資料)與POST(更新資料或者上傳檔案)
  • URL:通常是客戶端請求的檔案的路徑,比如 /research/experiments.html, 但是是否響應檔案都是由伺服器決定的。
  • HTTP version:HTTP版本。通常是 HTTP/1.0 或 HTTP/1.1
  • header field:HTTP頭的鍵值對,做一些基本設定,就像下面這樣:
  1. #客戶端接受的資料型別

  2. Accept: text/html

  3. #客戶端接受的語言

  4. Accept-Language: en, fr

  5. If-Modified-Since: 16-May-2005

  • body: 一些與請求有關的負載資料。比如在一個網站登陸的時候提交登陸表單,那負載資料就是你的賬號與密碼資訊。

HTTP響應的結構類似於請求:

  • status code:狀態碼。請求成功響應200,請求的檔案找不到則響應404。
  • status phrase:對狀態碼的描述。

  WEB伺服器、應用程式伺服器、HTTP伺服器有何區別?IIS、Apache、Tomcat、Weblogic、WebSphere都各屬於哪種伺服器,這些問題困惑了很久,今天終於梳理清楚了:

    Web伺服器的基本功能就是提供Web資訊瀏覽服務。它只需支援HTTP協議、HTML文件格式及URL。與客戶端的網路瀏覽器配合。因為Web伺服器主要支援的協議就是HTTP,所以通常情況下HTTP伺服器和WEB伺服器是相等的(有沒有支援除HTTP之外的協議的web伺服器,作者沒有考證過),說的是一回事。 

  應用程式伺服器(簡稱應用伺服器),我們先看一下微軟對它的定義:"我們把應用程式伺服器定義為“作為伺服器執行共享業務應用程式的底層的系統軟體”。 就像檔案伺服器為很多使用者提供檔案一樣,應用程式伺服器讓多個使用者可以同時使用應用程式(通常是客戶建立的應用程式)"

  通俗的講,Web伺服器傳送(serves)頁面使瀏覽器可以瀏覽,然而應用程式伺服器提供的是客戶端應用程式可以呼叫(call)的方法(methods)。確切一點,你可以說:Web伺服器專門處理HTTP請求(request),但是應用程式伺服器是通過很多協議來為應用程式提供(serves)商業邏輯 (business logic)。

  以Java EE為例,Web伺服器主要是處理靜態頁面處理和作為 Servlet容器,解釋和執行servlet/JSP,而應用伺服器是執行業務邏輯的,主要是EJB、 JNDI和JMX API等J2EE API方面的,還包含事務處理、資料庫連線等功能,所以在企業級應用中,應用伺服器提供的功能比WEB伺服器強大的多。

  以這樣的定義,IIS、Apache、Tomcat都可以屬於Web伺服器,Weblogic、WebSphere都屬於應用伺服器。 

  Apache:在Web伺服器中,Apache是純粹的Web伺服器,經常與Tomcat配對使用。它對HTML頁面具有強大的解釋能力,但是不能解釋嵌入頁面內的伺服器端指令碼程式碼(JSP/Servlet)。 

  Tomcat:早期的Tomcat是一個嵌入Apache內的JSP/Servlet解釋引擎Apache+Tomcat就相當於IIS+ASP。後來的Tomcat已不再嵌入Apache內,Tomcat程序獨立於Apache程序執行。 而且,Tomcat已經是一個獨立的Servlet和JSP容器,業務邏輯層程式碼和介面互動層程式碼可以分離了。因此,有人把Tomcat叫做輕量級應用伺服器。 

  IIS:微軟早期的IIS,就是一個純粹的Web伺服器。後來,它嵌入了ASP引擎,可以解釋VBScript和JScript伺服器端程式碼了,這時,它就可以兼作應用伺服器。當然,它與J2EE應用伺服器根本無法相比,但是,從功能上說,從原理上說,它勉強可以稱之為應用伺服器。確切地說,它是兼有一點應用伺服器功能的Web伺服器。 

  綜上:Apache是純粹的web伺服器,而Tomcat和IIS因為具有了解釋執行伺服器端程式碼的能力,可以稱作為輕量級應用伺服器或帶有伺服器功能的Web伺服器。Weblogic、WebSphere因為能提供強大的J2EE功能,毫無疑問是絕對的應用伺服器。對於處於中間位置的Tomcat,它可以配合純Web伺服器Apache一起使用,也可以作為應用伺服器的輔助與應用伺服器一起部署:

一、Tomcat與應用伺服器

   到目前為止,Tomcat一直被認為是Servlet/JSP API的執行器,也就所謂的Servlet容器。然而,Tomcat並不僅僅如此,它還提供了JNDI和JMX API的實現機制。儘管如此,Tomcat仍然還不能算是應用伺服器,因為它不提供大多數J2EE API的支援。

  很有意思的是,目前許多的應用伺服器通常把Tomcat作為它們Servlet和JSP API的容器。由於Tomcat允許開發者只需通過加入一行致謝,就可以把Tomcat嵌入到它們的應用中。遺憾的是,許多商業應用伺服器並沒有遵守此規則。

  對於開發者來說,如果是為了尋找利用Servlet、JSP、JNDI和JMX技術來生成Java Web應用的話,選擇Tomcat是一個優秀的解決方案;但是為了尋找支援其他的J2EE API,那麼尋找一個應用伺服器或者把Tomcat作為應用伺服器的輔助,將是一個不錯的解決方案;第三種方式是找到獨立的J2EE API實現,然後把它們跟Tomcat結合起來使用。雖然整合會帶來相關的問題,但是這種方式是最為有效的。。

二、Tomcat與Web伺服器

  Tomcat是提供一個支援Servlet和JSP執行的容器。Servlet和JSP能根據實時需要,產生動態網頁內容。而對於Web伺服器來說, Apache僅僅支援靜態網頁,對於支援動態網頁就會顯得無能為力;Tomcat則既能為動態網頁服務,同時也能為靜態網頁提供支援。儘管它沒有通常的Web伺服器快、功能也不如Web伺服器豐富,但是Tomcat逐漸為支援靜態內容不斷擴充。大多數的Web伺服器都是用底層語言編寫如C,利用了相應平臺的特徵,因此用純Java編寫的Tomcat執行速度不可能與它們相提並論。

  一般來說,大的站點都是將Tomcat與Apache的結合,Apache負責接受所有來自客戶端的HTTP請求,然後將Servlets和JSP的請求轉發給Tomcat來處理。Tomcat完成處理後,將響應傳回給Apache,最後Apache將響應返回給客戶端。

  而且為了提高效能,可以一臺apache連線多臺tomcat實現負載平衡。 

  關於WEB伺服器、應用程式伺服器的更詳細區別可以參考下面這篇文章: 

   通俗的講,Web伺服器傳送(serves)頁面使瀏覽器可以瀏覽,然而應用程式伺服器提供的是客戶端應用程式可以呼叫(call)的方法(methods)。確切一點,你可以說:Web伺服器專門處理HTTP請求(request),但是應用程式伺服器是通過很多協議來為應用程式提供(serves)商業邏輯 (business logic)。  

  下面讓我們來細細道來:

  Web伺服器(Web Server) 

  Web伺服器可以解析(handles)HTTP協議。當Web伺服器接收到一個HTTP請求(request),會返回一個HTTP響應 (response),例如送回一個HTML頁面。為了處理一個請求(request),Web伺服器可以響應(response)一個靜態頁面或圖片,進行頁面跳轉(redirect),或者把動態響應(dynamic response)的產生委託(delegate)給一些其它的程式例如CGI指令碼,JSP(JavaServer Pages)指令碼,servlets,ASP(Active Server Pages)指令碼,伺服器端(server-side)JavaScript,或者一些其它的伺服器端(server-side)技術。無論它們(譯者注:指令碼)的目的如何,這些伺服器端(server-side)的程式通常產生一個HTML的響應(response)來讓瀏覽器可以瀏覽。

  要知道,Web伺服器的代理模型(delegation model)非常簡單。當一個請求(request)被送到Web伺服器裡來時,它只單純的把請求(request)傳遞給可以很好的處理請求 (request)的程式(譯者注:伺服器端指令碼)。Web伺服器僅僅提供一個可以執行伺服器端(server-side)程式和返回(程式所產生的)響應(response)的環境,而不會超出職能範圍。伺服器端(server-side)程式通常具有事務處理(transaction processing),資料庫連線(database connectivity)和訊息(messaging)等功能。

  雖然Web伺服器不支援事務處理或資料庫連線池,但它可以配置(employ)各種策略(strategies)來實現容錯性(fault tolerance)和可擴充套件性(scalability),例如負載平衡(load balancing),緩衝(caching)。叢集特徵(clustering—features)經常被誤認為僅僅是應用程式伺服器專有的特徵。

  應用程式伺服器(The Application Server) 

  根據我們的定義,作為應用程式伺服器,它通過各種協議,可以包括HTTP,把商業邏輯暴露給(expose)客戶端應用程式。Web伺服器主要是處理向瀏覽器傳送HTML以供瀏覽,而應用程式伺服器提供訪問商業邏輯的途徑以供客戶端應用程式使用。應用程式使用此商業邏輯就象你呼叫物件的一個方法 (或過程語言中的一個函式)一樣。

  應用程式伺服器的客戶端(包含有圖形使用者介面(GUI)的)可能會執行在一臺PC、一個Web伺服器或者甚至是其它的應用程式伺服器上。在應用程式伺服器與其客戶端之間來回穿梭(traveling)的資訊不僅僅侷限於簡單的顯示標記。相反,這種資訊就是程式邏輯(program logic)。正是由於這種邏輯取得了(takes)資料和方法呼叫(calls)的形式而不是靜態HTML,所以客戶端才可以隨心所欲的使用這種被暴露的商業邏輯。

  在大多數情形下,應用程式伺服器是通過元件 (component) 的應用程式介面(API)把商業邏輯暴露(expose)(給客戶端應用程式)的,例如基於J2EE(Java 2 Platform, Enterprise Edition)應用程式伺服器的EJB(Enterprise JavaBean)元件模型。此外,應用程式伺服器可以管理自己的資源,例如看大門的工作(gate-keeping duties)包括安全(security),事務處理(transaction processing),資源池(resource pooling),和訊息(messaging)。就象Web伺服器一樣,應用程式伺服器配置了多種可擴充套件(scalability)和容錯(fault tolerance)技術。

一個例子 

  例如,設想一個線上商店(網站)提供實時定價(real-time pricing)和有效性(availability)資訊。這個站點(site)很可能會提供一個表單(form)讓你來選擇產品。當你提交查詢 (query)後,網站會進行查詢(lookup)並把結果內嵌在HTML頁面中返回。網站可以有很多種方式來實現這種功能。我要介紹一個不使用應用程式伺服器 的情景和一個使用應用程式伺服器的情景。觀察一下這兩中情景的不同會有助於你瞭解應用程式伺服器的功能。

情景1:不帶應用程式伺服器的Web伺服器 

  在此種情景下,一個Web伺服器獨立提供線上商店的功能。Web伺服器獲得你的請求(request),然後傳送給伺服器端(server- side)可以處理請求(request)的程式。此程式從資料庫或文字檔案(flat file,譯者注:flat file是指沒有特殊格式的非二進位制的檔案,如properties和XML檔案等)中查詢定價資訊。一旦找到,伺服器端(server-side)程式把結果資訊表示成(formulate)HTML形式,最後Web伺服器把會它傳送到你的Web瀏覽器。

簡而言之,Web伺服器只是簡單的通過響應(response)HTML頁面來處理HTTP請求(request)。

情景2:帶應用程式伺服器的Web伺服器 

  情景2和情景1相同的是Web伺服器還是把響應(response)的產生委託(delegates)給指令碼(譯者注:伺服器端 (server-side)程式)。然而,你可以把查詢定價的商業邏輯(business logic)放到應用程式伺服器上。由於這種變化,此指令碼只是簡單的呼叫應用程式伺服器的查詢服務(lookup service),而不是已經知道如何查詢資料然後表示為(formulate)一個響應(response)。這時當該指令碼程式產生HTML響應(response)時就可以使用該服務的返回結果了。

  在此情景中,應用程式伺服器提供(serves)了用於查詢產品的定價資訊的商業邏輯。(伺服器的)這種功能(functionality)沒有指出有關顯示和客戶端如何使用此資訊的細節,相反客戶端和應用程式伺服器只是來回傳送資料。當有客戶端呼叫應用程式伺服器的查詢服務(lookup service)時,此服務只是簡單的查詢並返回結果給客戶端。

  通過從響應產生(response-generating)HTML的程式碼中分離出來,在應用程式之中該定價(查詢)邏輯的可重用性更強了。其他的客戶端,例如收款機,也可以呼叫同樣的服務(service)來作為一個店員給客戶結帳。相反,在情景1中的定價查詢服務是不可重用的因為資訊內嵌在 HTML頁中了。

  總而言之,在情景2的模型中,在Web伺服器通過迴應HTML頁面來處理HTTP請求(request),而應用程式伺服器則是通過處理定價和有效性(availability)請求(request)來提供應用程式邏輯的。

警告(Caveats)

  現在,XML Web Services已經使應用程式伺服器和Web伺服器的界線混淆了。通過傳送一個XML有效載荷(payload)給伺服器,Web伺服器現在可以處理資料和響應(response)的能力與以前的應用程式伺服器同樣多了。

  另外,現在大多數應用程式伺服器也包含了Web伺服器,這就意味著可以把Web伺服器當作是應用程式伺服器的一個子集(subset)。雖然應用程式伺服器包含了Web伺服器的功能,但是開發者很少把應用程式伺服器部署(deploy)成這種功能(capacity)(譯者注:這種功能是指既有應用程式伺服器的功能又有Web伺服器的功能)。相反,如果需要,他們通常會把Web伺服器獨立配置,和應用程式伺服器一前一後。這種功能的分離有助於提高效能(簡單的Web請求(request)就不會影響應用程式伺服器了),分開配置(專門的Web伺服器,叢集(clustering)等等),而且給最佳產品的選取留有餘地。

<7>瞭解和簡單的服務

server 有兩重意思

  1. 有時候 server 表示硬體,也就是一臺機器。它還有另一個名字:「主機」。
  2. 更多時候,server 表示軟體程式,這種程式主要用來對外提供某些服務,比如郵件服務、FTP 服務、資料庫服務、網頁服務等。

作為開發者,我們說 server 的時候,一般指的後者,也就是一個 24 小時執行的軟體程式。

一臺主機上面可以執行多個這樣的程式。

什麼是 Web Server?

顧名思義,Web Server 就是提供 Web 服務的 Server。

比如我們訪問 http:// http://baidu.com,其實就是在使用百度的 Server 提供的服務。

一般來說, Web Server 對外提供的是 HTTP 服務(也可以是其他服務),這就是為什麼我們的網址都以「http://」開頭。

如何提供 HTTP 服務?

下面是有 Node.js 寫的一個最簡單的 HTTP server

  1. // 檔名 index.js

  2. // 使用 node index.js 可執行本程式

  3. var http = require('http')

  4. var server = http.createServer( function (request, response){

  5. response.end('這是頁面內容,你請求的路徑是:' + request.url)

  6. })

  7. server.listen(8080, function(){

  8. console.log("正在監聽 %s 埠", 8080);

  9. });

你不用看懂這段程式,你只需要知道兩件事情:

  1. 這段程式監聽了當前機器的 8080 埠。
  2. 一旦外部訪問當前機器的 8080 埠,這段程式就會返回一段文字。

這就是一個最簡單的 HTTP server。

分類

提供 HTTP 服務的 server 分為兩類。

1. 靜態檔案伺服器

這種伺服器簡單地根據訪問路徑,返回對應的檔案。

比如使用者訪問 http:// 123.123.123.123:8080/a/b/c/d.html,那麼這種伺服器就會在網站根目錄找到 a/b/c/d.html 檔案,原樣返回給使用者。

2. 動態內容伺服器

這種伺服器返回的內容一般不是檔案,而是動態生成的字串(比如從資料庫中獲取的字串)。

<8>app server和web server的區別

app伺服器和web伺服器的區別是什麼呢?

簡單來說,web伺服器提供頁面給瀏覽器,而app伺服器提供客戶端可以呼叫的介面。具體而言,我們可以說:

         Web伺服器處理HTTP請求,而app伺服器基於多種不同的協議,處理應用程式的邏輯問題。

以下將詳細介紹它們之間的區別。

Web伺服器

web伺服器處理HTTP協議。當收到一個HTTP請求之後,web伺服器會返回一個HTTP響應,比如一個HTML頁面。為了處理請求,它可能響應一個靜態的HTML頁面、圖片、重定向,或者代理(delegate)其他動態響應。這些動態響應可以由其他程式生成,包括CGI指令碼,JSPs,servlets,ASPs,伺服器端的Javascript,或者其他伺服器端技術。而這些伺服器端程式響應,大多數時候都表現為HTML頁面,供瀏覽器訪問。

理解一個web伺服器的代理模型(delegate model)相對比較簡單。當web伺服器接收到一個請求,它只是簡單的將請求交給處理該請求的最優程式。除了為伺服器程式簡單的提供一個執行環境(伺服器程式可以在其中執行,並且返回生成的響應)之外,web伺服器不提供任何功能。伺服器程式一般自己處理交換(transaction)、資料庫連線、訊息分發等。

雖然web伺服器不提供以上的服務,但是它一般會提供諸如容錯機制,負載均衡、快取、叢集等的可擴充套件性。而後者,一般來說不應該部署在web伺服器上,而應該在app伺服器上!

App伺服器

根據我們的定義,app伺服器可以基於各種不同的協議(可能包含HTTP協議),為客戶端程式提供應用邏輯的處理。不同於web伺服器主要傳送用來展示在瀏覽器上的HTML頁面,app伺服器為客戶端程式處理應用邏輯方面問題。應用程式使用這些邏輯,就如同呼叫一個物件的方法(或者面向過程程式設計中的函式)一樣簡單。

這些應用程式可能包含PC機上執行的GUI程序,web伺服器,甚至其他的app伺服器。app伺服器和客戶端之間的通訊並不侷限於簡單的顯示標記,而是可以由程式邏輯,比如資料表單、方法呼叫,而非靜態的HTML,這樣,客戶端程式就可以按需去用了!

在大多數情況下,app伺服器通過元件API,比如基於j2ee app伺服器的EJB,來提供應用邏輯。而更多的情況下,app伺服器自己管理自己的資源。這些責任(gate-keeping)包括安全、程序互動、資源池、訊息分發等。同web伺服器一樣,app伺服器也可能需要各種可擴充套件性和容錯機制。

一個例子

以一個提供實時價格和相關資訊的線上商店為例,它極有可能提供了一個表單,使用者可以選擇不同的產品並查詢。它會查詢,並通過HTML網頁展示結果。這個網站可能有多種方式來實現這個功能,下面我們將舉兩個相反的例子,一個不使用app伺服器,而另一個使用。通過這兩個例子,可以幫助你理解app伺服器的功能。

場景1:web伺服器,而非app伺服器

在這個場景裡,web伺服器獨自提供線上商店的功能。它接受使用者的請求,交給伺服器端程式處理。該伺服器端程式通過資料庫,或者純文字,查詢到價格資訊,然後生成HTML響應,通過web伺服器返回給使用者的瀏覽器。

總結來說,web伺服器僅需要接受HTTP請求,並響應HTML網頁。

場景2: web伺服器 + app伺服器

同場景1一樣,web伺服器仍然代理指令碼生成的響應。但是你可以把業務邏輯部署在app伺服器上。這樣,指令碼就不需要去關注怎樣查詢和生成響應,而僅需要呼叫app伺服器提供查詢服務,從而利用其生成它的HTML響應。

在這個例子中,app伺服器提供了價格查詢的業務邏輯。這個邏輯不應該包含怎樣去展示,或者強迫客戶端使用這些資料。相反的是,客戶端和app伺服器進行互動,只有當客戶端呼叫了app伺服器的價格查詢服務的時候,該服務才查詢到資訊並返回。

同HTML程式碼生成分離開後,價格查詢邏輯的複用性提高了。另外一個客戶端,比如收銀機,同樣可以呼叫這個介面。而場景1裡,價格查詢服務就很難被重用,因為它和HTML頁面緊密聯絡。

總結來說,第二個場景中,web伺服器處理HTTP請求,並返回HTML頁面,而app伺服器處理業務邏輯。

注意事項

近來,XML web伺服器模糊了app伺服器和web伺服器的界限。傳送一個XML請求給web伺服器,web伺服器可以像過去的app伺服器一樣,處理資料並返回響應。

另外,很多app伺服器包含web伺服器,這就意味著你可以把web伺服器看做app伺服器的一個子集。雖然app伺服器包含web伺服器的功能,但是開發者還是很少以此身份釋出app伺服器。如果需要的話,他們通常將web伺服器和app伺服器分離開。這樣的目的是,效能(簡單的web請求不會影響到app伺服器的效能)、釋出配置(專用的web伺服器,叢集等)、更好的廠商選擇。

<9>應用伺服器和web伺服器

Web伺服器的基本功能就是提供Web資訊瀏覽服務。它只需支援HTTP協議、HTML文件格式及URL。與客戶端的網路瀏覽器配合。因為Web伺服器主 要支援的協議就是HTTP,所以通常情況下HTTP伺服器和WEB伺服器是相等的。

以這樣的定義,IIS、Apache、Tomcat都可以屬於Web伺服器

       Web伺服器(Web Server)可以解析(handles)HTTP協議。當Web伺服器接收到一個HTTP請求(request),會返回一個HTTP響應 (response),例如送回一個HTML頁面。為了處理一個請求(request),Web伺服器可以響應(response)一個靜態頁面或圖片, 進行頁面跳轉(redirect),或者把動態響應(dynamic response)的產生委託(delegate)給一些其它的程式例如CGI指令碼,JSP(JavaServer Pages)指令碼,servlets,ASP(Active Server Pages)指令碼,伺服器端(server-side)JavaScript,或者一些其它的伺服器端(server-side)技術。無論它們(譯者 注:指令碼)的目的如何,這些伺服器端(server-side)的程式通常產生一個HTML的響應(response)來讓瀏覽器可以瀏覽。

       要知道,Web伺服器的代理模型(delegationmodel)非常簡單。當一個請求(request)被送到Web伺服器裡來時,它只單純的把請求(request)傳遞給可以很好的處理請求 (request)的程式(譯者注:伺服器端指令碼)。Web伺服器僅僅提供一個可以執行伺服器端(server-side)程式和返回(程式所產生的)響 應(response)的環境,而不會超出職能範圍。伺服器端(server-side)程式通常具有事務處理(transaction processing),資料庫連線(database connectivity)和訊息(messaging)等功能。

       雖然Web 伺服器不支援事務處理或資料庫連線池,但它可以配置(employ)各種策略(strategies)來實現容錯性(fault tolerance)和可擴充套件性(scalability),例如負載平衡(load balancing),緩衝(caching)。叢集特徵(clustering-features)經常被誤認為僅僅是應用程式伺服器專有的特徵。

應用伺服器(The Application Server)

微軟給定義為:我們把應用程式伺服器定義為“作為伺服器執行共享業務應用程式的底層的系統軟體。

根據定義,作為應用程式伺服器,它通過各種協議,可以包括HTTP,把商業邏輯暴露給(expose)客戶端應用程式。Web伺服器主要是處理向 瀏覽器傳送HTML以供瀏覽,而應用程式伺服器提供訪問商業邏輯的途徑以供客戶端應用程式使用。應用程式使用此商業邏輯就像你呼叫物件的一個方法(或過程 語言中的一個函式)一樣。

       應用程式伺服器的客戶端(包含有圖形使用者介面(GUI)的)可能會執行在一臺PC、一個Web伺服器或者甚至 是其它的應用程式伺服器上。在應用程式伺服器與其客戶端之間來回穿梭(traveling)的資訊不僅僅侷限於簡單的顯示標記。相反,這種資訊就是程式邏輯(program logic)。 正是由於這種邏輯取得了(takes)資料和方法呼叫(calls)的形式而不是靜態HTML,所以客戶端才可以隨心所欲的使用這種被暴露的商業邏輯。

       在大多數情形下,應用程式伺服器是通過元件(component)的應用程式介面(API)把商業邏輯暴露(expose)(給客戶端應用程式)的,例 如基於J2EE(Java 2 Platform, Enterprise Edition)應用程式伺服器的EJB(Enterprise JavaBean)元件模型。此外,應用程式伺服器可以管理自己的資源,例如看大門的工作(gate-keepingduties)包括安全(security),事務處理(transaction processing),資源池(resource pooling), 和訊息(messaging)。就象Web伺服器一樣,應用程式伺服器配置了多種可擴充套件(scalability)和容錯(fault tolerance)技術。

  以這樣的定義,Weblogic、WebSphere都屬於應用伺服器。

       Apache:在Web伺服器中,Apache是純粹的Web伺服器,經常與Tomcat配對使用。它對HTML頁面具有強大的解釋能力,但是不能解釋嵌入頁面內的伺服器端指令碼程式碼(JSP/Servlet)。

       Tomcat:早期的Tomcat是一個嵌入Apache內的JSP/Servlet解釋引擎Apache+Tomcat就相當於IIS+ASP。後來的 Tomcat已不再嵌入Apache內,Tomcat程序獨立於Apache程序執行。 而且,Tomcat已經是一個獨立的Servlet和JSP容器,業務邏輯層程式碼和介面互動層程式碼可以分離了。因此,有人把Tomcat叫做輕量級應用伺服器。

        IIS:微軟早期的IIS,就是一個純粹的Web伺服器。後來,它嵌入了ASP引擎,可以解釋VBScript和JScript伺服器端程式碼了,這時,它 就可以兼作應用伺服器。當然,它與J2EE應用伺服器根本無法相比,但是,從功能上說,從原理上說,它勉強可以稱之為應用伺服器。確切地說,它是兼有一點應用伺服器功能的Web伺服器。

       綜上:Apache是純粹的web伺服器,而Tomcat和IIS因為具有了解釋執行伺服器端程式碼的能力,可以稱作為輕量級應用伺服器或帶有伺服器功能的Web伺服器。 Weblogic、WebSphere因為能提供強大的J2EE功能,毫無疑問是絕對的應用伺服器。對於處於中間位置的Tomcat,它可以配合純Web伺服器Apache一起使用,也可以作為應用伺服器的輔助與應用伺服器一起部署。

常見的web伺服器: (其實IIS和Apache同時也支援基礎的應用伺服器的功能)

  Microsoft IIS

  Microsoft的Web伺服器產品為Internet Information Server (IIS), IIS 是允許在公共Intranet或Internet上釋出資訊的Web伺服器。IIS是目前最流行的Web伺服器產品之一,很多著名的網站都是建立在IIS 的平臺上。IIS提供了一個圖形介面的管理工具,稱為 Internet服務管理器,可用於監視配置和控制Internet服務。

  IIS是一種Web服務元件,其中包括Web伺服器、FTP伺服器、NNTP伺服器和SMTP伺服器, 分別用於網頁瀏覽、檔案傳輸、新聞服務和郵件傳送等方面,它使得在網路(包括網際網路和區域網)上釋出資訊成了一件很容易的事。它提供 ISAPI(Intranet Server API)作為擴充套件Web伺服器功能的程式設計介面;同時,它還提供一個Internet資料庫聯結器,可以實現對資料庫的查詢和更新。

       Apache

       Apache 源於NCSAhttpd伺服器,經過多次修改,成為世界上最流行的Web伺服器軟體之一。 Apache是自由軟體,所以不斷有人來為它開發新的功能、新的特性、修改原來的缺陷。Apache的特點是簡單、速度快、效能穩定,並可做代理伺服器來 使用。本來它只用於小型或試驗Internet網路,後來逐步擴充到各種Unix系統中,尤其對Linux的支援相當完美。

   Apache是以程序為基礎的結構,程序要比執行緒消耗更多的系統開支,不太適合於多處理器環境,因此, 在一個Apache Web站點擴容時,通常是增加伺服器或擴充群集節點而不是增加處理器。到目前為止Apache仍然是世界上用的最多的Web伺服器,世界上很多著名的網站 都是Apache的產物,它的成功之處主要在於它的原始碼開放、有一支開放的開發隊伍、支援跨平臺的應用(可以執行在幾乎所有的Unix、 Windows、Linux系統平臺上)以及它的可移植性等方面。

常見的應用伺服器:

  IBM WebSphere

  WebSphere Application Server 是一 種功能完善、開放的Web應用程式伺服器,是IBM電子商務計劃的核心部分,它是基於 Java 的應用環境,用於建立、部署和管理 Internet 和 Intranet Web 應用程式。 這一整套產品進行了擴充套件,以適應 Web 應用程式伺服器的需要,範圍從簡單到高階直到企業級。

  WebSphere 針對以 Web 為中心的開發人員,他們都是在基本 HTTP伺服器和 CGI 程式設計技術上成長起來的。IBM 將提供 WebSphere 產品系列,通過提供綜合資源、可重複使用的元件、功能強大並易於使用的工具、以及支援 HTTP 和 IIOP 通訊的可伸縮執行時環境,來幫助這些使用者從簡單的 Web 應用程式轉移到電子商務世界。

  BEA WebLogic

  BEA WebLogic Server 是一種多功能、基於標準的web應用伺服器,為企業構建自己的應用提供了堅實的基礎。各種應用開發、部署所有關鍵性的任務,無論是整合各種系統和資料庫,還是提交服務、跨 Internet 協作,起始點都是 BEA WebLogic Server。由於 它具有全面的功能、對開放標準的遵從性、多層架構、支援基於元件的開發,基於 Internet 的企業都選擇它來開發、部署最佳的應用。

  BEA WebLogic Server 在使應用伺服器成為企業應用架構的基礎方面繼續處於領先地位。BEA WebLogic Server 為構建整合化的企業級應用提供了穩固的基礎,它們以 Internet 的容量和速度,在連網的企業之間共享資訊、提交服務,實現協作自動化。BEA WebLogic Server 的遵從 J2EE 、面向服務的架構,以及豐富的工具集支援,便於實現業務邏輯、資料和表達的分離,提供開發和部署各種業務驅動應用所必需的底層核心功能。現在已經歸於Oracle所有。

  IPlanet Application

  IPlanet Application Server作為Sun與Netscape聯盟產物的iPlanet公司生產的iPlanet Application Server 滿足最新J2EE規範的要求。它是一種完整的WEB伺服器應用解決方案,它允許企業以便捷的方式,開發、部署和管理關鍵任務Internet 應用。該解決方案集高效能、高度可伸縮和高度可用性於一體,可以支援大量的具有多種客戶機型別與資料來源的事務。

  iPlanet Application Server的基本核心服務包括事務監控器、多負載平衡選項、對叢集和故障轉移全面的支援、整合的XML 解析器和可擴充套件格式語言轉換(XLST)引擎以及對國際化的全面支援。iPlanet ApplicationServer 企業版所提供的全部特性和功能,並得益於J2EE系統構架,擁有更好的商業工作流程管理工具和應用整合功能。

  Oracle IAS

  Oracle iAS的英文全稱是Oracle Internet Application Server,即Internet應用伺服器,Oracle iAS是基於Java的應用伺服器,通過與Oracle資料庫等產品的結合,OracleiAS能夠滿足Internet應用對可靠性、可用性和可伸縮性的要求。

  Oracle iAS最大的優勢是其整合性和通用性,它是一個整合的、通用的中介軟體產品。在整合性方面,Oracle iAS將業界最流行的HTTP伺服器Apache整合到系統中,集成了Apache的Oracle iAS通訊服務層可以處理多種客戶請求,包括來自Web瀏覽器、胖客戶端和手持裝置的請求,並且根據請求的具體內容,將它們分發給不同的應用服務進行處 理。在通用性方面,Oracle iAS支援各種業界標準,包括 JavaBeans、CORBA、Servlets以及XML標準等,這種對標準的全面支援使得使用者很容易將在其他系統平臺上開發的應用移植到 Oracle平臺上。

  Tomcat

  Tomcat是一個開放原始碼、執行servlet和JSP Web應用軟體的基於Java的Web應用軟體容器。Tomcat Server是根據servlet和JSP規範進行執行的,因此我們就可以說Tomcat Server也實行了Apache-Jakarta規範且比絕大多數商業應用軟體伺服器要好。

  Tomcat是Java Servlet2.2和JavaServerPages 1.1技術的標準實現,是基於Apache許可證下開發的自由軟體。Tomcat是完全重寫的Servlet API 2.2和JSP 1.1相容的Servlet/JSP容器。Tomcat使用了JServ的一些程式碼,特別是Apache服務介面卡。隨著Catalina Servlet引擎的出現,Tomcat第四版號的效能得到提升,使得它成為一個值得考慮的Servlet/JSP容器,因此目前許多WEB伺服器都是採用Tomcat。