J2EE的體系架構

轉載自:http://zengbo0710.iteye.com/blog/79490


J2EE 即Java2平臺企業版,它提供了基於組件的方式來設計、開發、組裝和部署企業應用。J2EE使用多層分佈式的應用模型,這個多層通常通過三層或四層來實現:

         1、客戶層,運行在客戶計算機上的組件。
         2、Web 層,運行在J2EE服務器上的組件。
         3、業務層,同樣是運行在J2EE服務器上的組件。
         4、企業信息系統層(EIS),是指運行在EIS服務器上的軟件系統。
      
         以上層次一般也指三層應用,因分佈在三個不同位置:客戶計算機、J2EE服務器及後臺的數據庫或過去遺留下來的系統。請看圖例:           

       J2EE組件

         J2EE應用程序是由組件構成的。J2EE組件是一個封裝了功能的軟件單元,能夠與相關的一些類和文件一起組成J2EE應用程序。
         1、應用程序客戶端和Applet是指運行在客戶計算機上的組件。
         2、基於Java Servlet和JSP技術的組件叫Web組件,它們運行在服務器上。
         3、企業JavaBean(EJB)組件叫業務組件,同樣運行在服務器上。

      J2EE客戶端

         J2EE客戶端可以是一個Web組件或者是一個應用程序客戶端。
         1、Web客戶端  
         包括兩部分,首先是那些動態Web頁面(HTML、XML等),這些組件運行在Web層;另一個是Web瀏覽器,由客戶機上的瀏覽器從服務器接收並且解析和顯示Web頁面。
         2、小應用程序(Applet) 
         需要運行在客戶端安裝了Java虛擬機的Web瀏覽器上。
         3、應用程序客戶端
         J2EE應用程序客戶端運行在客戶機上,能提供強大而靈活易用的用戶界面,如使用Swing或AWT創建的圖形化的用戶界面(GUI)。應用程序可直接訪問運行在業務層的企業Bean,如果需求允許,也可以打開HTTP連接來建立與運行在Web層上的Servlet之間的通訊。
         4、JavaBean組件架構
         在服務器和客戶端兩層中也可能包括了基於JavaBean的組件架構,通過JavaBean來實現數據的流動,可以是在應用程序客戶或Applet與運行在J2EE服務器上的組件之間,或者是在J2EE服務器和後臺數據庫之間。(不過JavaBean組件並沒有包含在J2EE規範裏)
         5、J2EE服務的通訊
         客戶層與J2EE服務器上運行的業務層之間的通訊可以是直接的,也可以通過運行在Web層中的Servlet和JSP來實現,在這種情況下,客戶運行在瀏覽器中。

         Web組件

         J2EE的Web組件可以是Servlet或JSP頁面。在應用程序組裝過程中,靜態HTML頁面和Applet也可以一起打包成Web組件,但這並不是J2EE規範所認可的Web組件。

         業務組件

         業務代碼是指那些由位於業務層的企業Bean(EJB)執行的邏輯,它們能夠解決或滿足特定的商業領域的一些需求。有三種不同類型的企業Bean:會話Bean、實體Bean和消息驅動Bean。會話Bean代表客戶一次短暫的會話過過程,當客戶執行完成後,會話Bean以及它所包含的數據也隨之消失。實體Bean代表的是持久的數據,即存儲在數據庫表中的一行記錄,即使客戶終止或者服務器關閉,在J2EE底層的會服務確保實體Bean的數據被保存下來。

         企業信息系統層

         企業信息系統層處理企業信息系統的軟件,包括企業組織結構系統,例如企業資源計劃(ERP)、大型的事務處理、數據庫系統及其他歷史上遺留下來的信息系統。


歸納幾個概念:

 EJB


         即Enterprise JavaBean,一種組件架構,用於開發和部署面向對象的、分佈式的、企業級的應用程序。所開發的應用程序使用EJB架構來實現可擴展性及管理事務和安全。
         EJB包括會話Bean(session bean)、實體Bean(entity bean)和消息驅動Bean(message-driven bean)。其中會話Bean分爲無狀態會話Bean(stateless session bean)和有狀態會話Bean(stateful session bean)。而實體Bean又分爲Bean管理實體Bean和容器管理實體Bean。由於這種Bean對應於數據庫中的記錄,所以數據庫記錄的任何改變也被同步到組件池中的相關Bean中,這個過程叫做持久性(persistenced),這是實體Bean最重要的一個特徵。根據持久性操作方式的不同分爲:容器管理持久性(Container-Managed Persistence,CMP)和Bean管理持久性(Bean-Managed Persistence,BMP)。

容器

         即container,一個實體,它管理着組件的生命週期、安全、部署和運行時服務。每個類型的容器都只提供與相應類型的組件相關的服務,如EJB、Web、JSP、Applet和應用程序客戶端。其中,EJB容器和Web容器都運行在J2EE服務器中。

J2EE

         即Java 2 Platform Enterprise Edition,Java 2 平臺企業版。是開發和部署企業應用程序的一種平臺或環境。它由一系列服務、應用程序編程接口(API)、提供多層開發的功能性的協議以及基於Web的應用程序組成。


J2EE的概念


目前,Java 2平臺有3個版本,它們是適用於小型設備和智能卡的Java 2平臺Micro版(Java 2 Platform Micro Edition,J2ME)、適用於桌面系統的Java 2平臺標準版(Java 2 Platform Standard Edition,J2SE)、適用於創建服務器應用程序和服務的Java 2平臺企業版(Java 2 Platform Enterprise Edition,J2EE)。

J2EE是一種利用Java 2平臺來簡化企業解決方案的開發、部署和管理相關的複雜問題的體系結構。J2EE技術的基礎就是核心Java平臺或Java 2平臺的標準版,J2EE不僅鞏固了標準版中的許多優點,例如"編寫一次、隨處運行"的特性、方便存取數據庫的JDBC API、CORBA技術以及能夠在Internet應用中保護數據的安全模式等等,同時還提供了對 EJB(Enterprise JavaBeans)、Java Servlets API、JSP(Java Server Pages)以及XML技術的全面支持。其最終目的就是成爲一個能夠使企業開發者大幅縮短投放市場時間的體系結構。

J2EE體系結構提供中間層集成框架用來滿足無需太多費用而又需要高可用性、高可靠性以及可擴展性的應用的需求。通過提供統一的開發平臺,J2EE降低了開發多層應用的費用和複雜性,同時提供對現有應用程序集成強有力支持,完全支持Enterprise JavaBeans,有良好的嚮導支持打包和部署應用,添加目錄支持,增強了安全機制,提高了性能。


J2EE的優勢


J2EE爲搭建具有可伸縮性、靈活性、易維護性的商務系統提供了良好的機制:

  1. 保留現存的IT資產: 由於企業必須適應新的商業需求,利用已有的企業信息系統方面的投資,而不是重新制定全盤方案就變得很重要。這樣,一個以漸進的(而不是激進的,全盤否定的)方式建立在已有系統之上的服務器端平臺機制是公司所需求的。J2EE架構可以充分利用用戶原有的投資,如一些公司使用的BEA Tuxedo、IBM CICS, IBM Encina,、Inprise VisiBroker 以及Netscape Application Server。這之所以成爲可能是因爲J2EE擁有廣泛的業界支持和一些重要的'企業計算'領域供應商的參與。每一個供應商都對現有的客戶提供了不用廢棄已有投資,進入可移植的J2EE領域的升級途徑。由於基於J2EE平臺的產品幾乎能夠在任何操作系統和硬件配置上運行,現有的操作系統和硬件也能被保留使用。
  2. 高效的開發: J2EE允許公司把一些通用的、很繁瑣的服務端任務交給中間件供應商去完成。這樣開發人員可以集中精力在如何創建商業邏輯上,相應地縮短了開發時間。高級中間件供應商提供以下這些複雜的中間件服務:
    • 狀態管理服務 -- 讓開發人員寫更少的代碼,不用關心如何管理狀態,這樣能夠更快地完成程序開發。
    • 持續性服務 -- 讓開發人員不用對數據訪問邏輯進行編碼就能編寫應用程序,能生成更輕巧,與數據庫無關的應用程序,這種應用程序更易於開發與維護。
    • 分佈式共享數據對象CACHE服務 -- 讓開發人員編制高性能的系統,極大提高整體部署的伸縮性。
  3. 支持異構環境: J2EE能夠開發部署在異構環境中的可移植程序。基於J2EE的應用程序不依賴任何特定操作系統、中間件、硬件。因此設計合理的基於J2EE的程序只需開發一次就可部署到各種平臺。這在典型的異構企業計算環境中是十分關鍵的。J2EE標準也允許客戶訂購與J2EE兼容的第三方的現成的組件,把他們部署到異構環境中,節省了由自己制訂整個方案所需的費用。
  4. 可伸縮性: 企業必須要選擇一種服務器端平臺,這種平臺應能提供極佳的可伸縮性去滿足那些在他們系統上進行商業運作的大批新客戶。基於J2EE平臺的應用程序可被部署到各種操作系統上。例如可被部署到高端UNIX與大型機系統,這種系統單機可支持64至256個處理器。(這是NT服務器所望塵莫及的)J2EE領域的供應商提供了更爲廣泛的負載平衡策略。能消除系統中的瓶頸,允許多臺服務器集成部署。這種部署可達數千個處理器,實現可高度伸縮的系統,滿足未來商業應用的需要。
  5. 穩定的可用性: 一個服務器端平臺必須能全天候運轉以滿足公司客戶、合作伙伴的需要。因爲INTERNET是全球化的、無處不在的,即使在夜間按計劃停機也可能造成嚴重損失。若是意外停機,那會有災難性後果。J2EE部署到可靠的操作環境中,他們支持長期的可用性。一些J2EE部署在WINDOWS環境中,客戶也可選擇健壯性能更好的操作系統如Sun Solaris、IBM OS/390。最健壯的操作系統可達到99.999%的可用性或每年只需5分鐘停機時間。這是實時性很強商業系統理想的選擇。

J2EE 的結構


這種基於組件,具有平臺無關性的J2EE 結構使得J2EE 程序的編寫十分簡單,因爲業務邏輯被封裝成可複用的組件,並且J2EE 服務器以容器的形式爲所有的組件類型提供後臺服務. 因爲你不用自己開發這種服務, 所以你可以集中精力解決手頭的業務問題.

容器和服務 
容器設置定製了J2EE服務器所提供得內在支持,包括安全,事務管理,JNDI(Java Naming and Directory Interface)尋址,遠程連接等服務,以下列出最重要的幾種服務:

  • J2EE安全(Security)模型可以讓你配置 web 組件或enterprise bean ,這樣只有被授權的用戶才能訪問系統資源. 每一客戶屬於一個特別的角色,而每個角色只允許激活特定的方法。你應在enterprise bean的佈置描述中聲明角色和可被激活的方法。由於這種聲明性的方法,你不必編寫加強安全性的規則。
  • J2EE 事務管理(Transaction Management)模型讓你指定組成一個事務中所有方法間的關係,這樣一個事務中的所有方法被當成一個單一的單元. 當客戶端激活一個enterprise bean中的方法,容器介入一管理事務。因有容器管理事務,在enterprise bean中不必對事務的邊界進行編碼。要求控制分佈式事務的代碼會非常複雜。你只需在佈置描述文件中聲明enterprise bean的事務屬性,而不用編寫並調試複雜的代碼。容器將讀此文件併爲你處理此enterprise bean的事務。
  • JNDI 尋址(JNDI Lookup)服務向企業內的多重名字和目錄服務提供了一個統一的接口,這樣應用程序組件可以訪問名字和目錄服務.
  • J2EE遠程連接(Remote Client Connectivity)模型管理客戶端和enterprise bean間的低層交互. 當一個enterprise bean創建後, 一個客戶端可以調用它的方法就象它和客戶端位於同一虛擬機上一樣.
  • 生存週期管理(Life Cycle Management)模型管理enterprise bean的創建和移除,一個enterprise bean在其生存週期中將會歷經幾種狀態。容器創建enterprise bean,並在可用實例池與活動狀態中移動他,而最終將其從容器中移除。即使可以調用enterprise bean的create及remove方法,容器也將會在後臺執行這些任務。
  • 數據庫連接池(Database Connection Pooling)模型是一個有價值的資源。獲取數據庫連接是一項耗時的工作,而且連接數非常有限。容器通過管理連接池來緩和這些問題。enterprise bean可從池中迅速獲取連接。在bean釋放連接之可爲其他bean使用。

容器類型 
J2EE應用組件可以安裝部署到以下幾種容器中去:

  • EJB 容器管理所有J2EE 應用程序中企業級bean 的執行. enterprise bean 和它們的容器運行在J2EE 服務器上.
  • Web 容器管理所有J2EE 應用程序中JSP頁面和Servlet組件的執行. Web 組件和它們的容器運行在J2EE 服務器上.
  • 應用程序客戶端容器管理所有J2EE應用程序中應用程序客戶端組件的執行. 應用程序客戶端和它們的容器運行在J2EE 服務器上.
  • Applet 容器是運行在客戶端機器上的web瀏覽器和 Java 插件的結合.


______________________________________________________________________________


J2EE的核心API與組件


J2EE平臺由一整套服務(Services)、應用程序接口(APIs)和協議構成,它對開發基於Web的多層應用提供了功能支持,下面對J2EE中的13種技術規範進行簡單的描述(限於篇幅,這裏只能進行簡單的描述):

  1. JDBC(Java Database Connectivity): JDBC API爲訪問不同的數據庫提供了一種統一的途徑,象ODBC一樣,JDBC對開發者屏蔽了一些細節問題,另外,JDCB對數據庫的訪問也具有平臺無關性。
  2. JNDI(Java Name and Directory Interface): JNDI API被用於執行名字和目錄服務。它提供了一致的模型來存取和操作企業級的資源如DNS和LDAP,本地文件系統,或應用服務器中的對象。
  3. EJB(Enterprise JavaBean): J2EE技術之所以贏得某體廣泛重視的原因之一就是EJB。它們提供了一個框架來開發和實施分佈式商務邏輯,由此很顯著地簡化了具有可伸縮性和高度複雜的企業級應用的開發。EJB規範定義了EJB組件在何時如何與它們的容器進行交互作用。容器負責提供公用的服務,例如目錄服務、事務管理、安全性、資源緩衝池以及容錯性。但這裏值得注意的是,EJB並不是實現J2EE的唯一途徑。正是由於J2EE的開放性,使得有的廠商能夠以一種和EJB平行的方式來達到同樣的目的。
  4. RMI(Remote Method Invoke): 正如其名字所表示的那樣,RMI協議調用遠程對象上方法。它使用了序列化方式在客戶端和服務器端傳遞數據。RMI是一種被EJB使用的更底層的協議。
  5. Java IDL/CORBA: 在Java IDL的支持下,開發人員可以將Java和CORBA集成在一起。他們可以創建Java對象並使之可在CORBA ORB中展開, 或者他們還可以創建Java類並作爲和其它ORB一起展開的CORBA對象的客戶。後一種方法提供了另外一種途徑,通過它Java可以被用於將你的新的應用和舊的系統相集成。
  6. JSP(Java Server Pages): JSP頁面由HTML代碼和嵌入其中的Java代碼所組成。服務器在頁面被客戶端所請求以後對這些Java代碼進行處理,然後將生成的HTML頁面返回給客戶端的瀏覽器。
  7. Java Servlet: Servlet是一種小型的Java程序,它擴展了Web服務器的功能。作爲一種服務器端的應用,當被請求時開始執行,這和CGI Perl腳本很相似。Servlet提供的功能大多與JSP類似,不過實現的方式不同。JSP通常是大多數HTML代碼中嵌入少量的Java代碼,而servlets全部由Java寫成並且生成HTML。
  8. XML(Extensible Markup Language): XML是一種可以用來定義其它標記語言的語言。它被用來在不同的商務過程中共享數據。XML的發展和Java是相互獨立的,但是,它和Java具有的相同目標正是平臺獨立性。通過將Java和XML的組合,您可以得到一個完美的具有平臺獨立性的解決方案。
  9. JMS(Java Message Service): MS是用於和麪向消息的中間件相互通信的應用程序接口(API)。它既支持點對點的域,有支持發佈/訂閱(publish/subscribe)類型的域,並且提供對下列類型的支持:經認可的消息傳遞,事務型消息的傳遞,一致性消息和具有持久性的訂閱者支持。JMS還提供了另一種方式來對您的應用與舊的後臺系統相集成。
  10. JTA(Java Transaction Architecture): JTA定義了一種標準的API,應用系統由此可以訪問各種事務監控。
  11. JTS(Java Transaction Service): JTS是CORBA OTS事務監控的基本的實現。JTS規定了事務管理器的實現方式。該事務管理器是在高層支持Java Transaction API (JTA)規範,並且在較底層實現OMG OTS specification的Java映像。JTS事務管理器爲應用服務器、資源管理器、獨立的應用以及通信資源管理器提供了事務服務。
  12. JavaMail: JavaMail是用於存取郵件服務器的API,它提供了一套郵件服務器的抽象類。不僅支持SMTP服務器,也支持IMAP服務器。
  13. JTA(JavaBeans Activation Framework): JavaMail利用JAF來處理MIME編碼的郵件附件。MIME的字節流可以被轉換成Java對象,或者轉換自Java對象。大多數應用都可以不需要直接使用JAF。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章