1. 程式人生 > >常用 J2EE 應用伺服器比較

常用 J2EE 應用伺服器比較

Weblogic和Tomcat的區別

J2ee開發主要是瀏覽器和伺服器進行互動的一種結構.邏輯都是在後臺進行處理,然後再把結果傳輸回給瀏覽器。可以看出伺服器在這種架構是非常重要的。
       這幾天接觸到兩種Java的web伺服器,做專案用的Tomcat,看視訊看的是WebLogic Server(WLS),都是web伺服器,有什麼區別和聯絡呢?
        (一)先簡單介紹一下這兩種伺服器。
       WebLogic是美國bea公司出品的一個application server,確切的說是一個基於Javaee架構的中介軟體,純java開發的,最新版本WebLogic Server 9.0是迄今為止釋出的最卓越的BEA應用伺服器。BEA WebLogic是用於開發、整合、部署和管理大型分散式Web應用、網路應用和資料庫應用的
Java應用伺服器
。將Java的動態功能和Java Enterprise標準的安全性引入大型網路應用的開發、整合、部署和管理之中。完全遵循J2EE 1.4規範。 Tomcat伺服器是一個免費的開源的Web 應用伺服器,是Apache 軟體基金會的Jakarta 專案中的一個核心專案,由Apache、Sun 和其他一些公司及個人共同開發而成。因為Tomcat 技術先進、效能穩定,執行時佔用的系統資源小,擴充套件性好,支援負載平衡與郵件服務等開發應用系統常用的功能;而且很重要的是她免費,因而深受Java 愛好者的喜愛並得到了部分軟體開發商的認可,成為目前比較流行的Web 應用伺服器。而且由於開源,它還在不斷的改進和完善中,任何一個感興趣的程式設計師都可以更改它或在其中加入新的功能。 (二)相同點: WebLogic和Tomcat都是基於java的基礎架構來滿足實時處理需求,不同的版本與jdk版本相容和有所不同;因為都是要和前臺互動,所以他們都基於
sun公司
的servlet來實現的。 (三)不同點: 功能性: WebLogic更加強大。weblogic是j2ee的應用伺服器(application server),包括ejb ,jsp,servlet,jms等等,全能型的。是商業軟體裡排名第一的容器(JSP、servlet、EJB等),並提供其他如JAVA編輯等工具,是一個綜合的開發及執行環境。 WebLogic應該是J2EE Container(Web Container + EJB Container + XXX規範)! Tomcat只能算Web Container,是官方指定的JSP&Servlet容器。只實現了JSP/Servlet的相關規範,不支援EJB(硬傷啊)!不過Tomcat配合jboss和apache可以實現
j2ee應用伺服器
功能 一般來說考慮stucts等架構tomcat就可以了,但如果考慮EJB的話,WebLogic是比較好的選擇。 擴充套件性: 用WebLogic執行標準的java可能並不是最好的方式,WebLogic裡支援他自己的一些東西,這些東西雖然是在純java基礎上開發的,但其他工具裡都沒有。WebLogic Server憑藉其出色的群集技術,擁有處理關鍵Web應用系統問題所需的效能、可擴充套件性高可用性。 WebLogic Server既實現了網頁群集,也實現了EJB元件 群集,而且不需要任何專門的硬體或作業系統支援。網頁群集可以實現透明的複製、負載平衡以及表示內容容錯 。 無論是網頁群集,還是元件群集,對於電子商務解決方案所要求的可擴充套件性和可用性都是至關重要的。共享的客戶機/伺服器和資料庫連線以及資料快取和EJB都增強了效能表現。這是其它Web應用系統所不具備的 所以,在擴充套件性方面WebLogic是遠遠超越了Tomcat。 費用上: Tomcat開源免費。 WebLogic不開源不免費。 總之,在功能強大和擴充套件性和可用性等方面WLS比Tomcat好很多,但這也不能說明WLS適合每一方面,從Tomcat的使用流行度便可以看出,Tomcat雖功能有限,但也很受歡迎。其實關鍵看你要做什麼。 Tomcat 是免費開源的jsp,servlet引擎,入門級別的Web伺服器,剛入門的IT人使用Tomcat簡單易上手。而且它一個輕量級應用伺服器,最重要的是它免費,所以在中小型系統和併發訪問使用者不是很多的場合下被普遍使用,是開發和除錯JSP 程式的首選。Tomcat比較輕巧,消耗資源較少。當然,專案大的時候,WLS肯定再合適不過,而且Tomcat也無法滿足太多需求,但是,WLS的費用也是不可小覷的。 總之,關鍵看你做什麼,權衡利弊做選擇。 此外,還有其他J2EE Application Server,例如: IBM的websphere、Sun的Glassfish、resin等。Apache全球應用最廣泛的http伺服器,免費。同樣開源免費的JBoss, 國內廠商生產的還有像東方通的Tongweb、金蝶Apusic應用伺服器等。都是應用比較廣泛的。
-----------------------------------------------------------------

沒辦法比哦,jboss 與 tomcat 的應用場合不一樣。

JBoss 是 J2EE 應用伺服器,而 Tomcat 只是一個 Servlet 容器,或者說是一個簡單的 J2EE 應用伺服器。

JBoss 中的 Servlet 容器還是 Tomcat。

與 Tomcat 類似的 Servlet 容器有:Jetty(開源), Resin(開源)……。
與 JBoss 類似的 J2EE 應用伺服器有:Glassfish(開源), Geronimo(開源), WebLogic(商業), WebSphere(商業)

-------------------------------------------------------------------

1. Tomcat是Apache鼎力支援的Java Web應用伺服器(注:servlet容器),由於它優秀的穩定性以及豐富的文件資料,廣泛的使用人群,從而在開源領域受到最廣泛的青睞。

  2. Jboss作為Java EE應用伺服器,它不但是Servlet容器,而且是EJB容器,從而受到企業級開發人員的歡迎,從而彌補了Tomcat只是一個Servlet容器的缺憾。

  3. Resin也僅僅是一個Servlet容器,然而由於它優秀的執行速度,使得它在輕量級Java Web領域備受喜愛,特別是在網際網路Web服務領域,眾多知名公司都採用其作為他們的Java Web應用伺服器,譬如163、ku6等。

  在商用應用伺服器裡主要有:Weblogic、Websphere,其中Weblogic我也使用過很長一段時間,當時也只用其當Servlet容器,然而就在同等條件下,在效能及易用性等方面,要比Tomcat優秀很多。

  4.glassfish是Sun公司推出的Java EE伺服器(Java EE容器),一個比較活躍的開源社群,不斷的通過社群的反饋來提高其的可用性,經過glassfish v1 glassfish v2 到今天的glassfish v3 ,它已經走向成熟。Glassfish是一個免費、開放原始碼的應用服務,它實現了Java EE 5,Java EE 5 平臺包括了以下最新技術:EJB 3.0、JSF 1.2、Servlet 2.5、JSP 2.1、JAX-WS 2.0、JAXB 2.0、 Java Persistence 1.0、Common Annonations 1.0、StAX 1.0等。

  支援叢集,通過記憶體中會話狀態複製,增強了部署體系結構的可用性與可伸縮性,它對叢集有著很好的支援,可以簡單到通過新增機器,就可輕鬆的提高網站的 帶負載能力,在解析能力方面,它對html的吞吐能力與apache伺服器不分上下,就是tomcat所不能比的,支援目錄部署,熱部署,解決了 tomcat對熱部署能力的缺陷。在版本方面做的更加人性化,有開發時用的簡化版,專門用於部署web專案的版本,還要完全符合j2ee標準的版本。

------------------------------------------------------------------------

WEB伺服器與應用伺服器的區別:

1.WEB伺服器:
理解WEB伺服器,首先你要理解什麼是WEB?WEB你可以簡單理解為你所看到的HTML頁面就是WEB的資料元素,處理這些資料元素的應用軟體就叫WEB伺服器,如IIS、apache。 WEB伺服器與客戶端打交道,它要處理的主要資訊有:session、request、response、HTML、JS、CS等。

2.應用伺服器:
應用伺服器如JSP,處理的是非常規性WEB頁面(JSP檔案),他動態生成WEB頁面,生成的WEB頁面在傳送給客戶端(實際上當應用伺服器處理完一個JSP請求並完成JSP生成HTML後它的任務就結束了,其餘的就是WEB處理的過程了)。

WEB伺服器與應用伺服器的聯絡:
1.WEB伺服器一般是通用的,而應用伺服器一般是專用的,如Tomcat只處理JAVA應用程式而不能處理ASPX或PHP。而Apache是一個WEB服 務器f(HTTP伺服器),後來連線Tomcat應用伺服器來支援java。

作者:iTech
出處:http://itech.cnblogs.com/
本文版權歸作者iTech所有,轉載請包含作者簽名和出處,不得用於商業用途,非則追究法律責任!

二。另述

   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都可以屬於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)等等),而且給 最佳產品的選取留有餘地