程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> JAVA編程入門知識 >> 理解Java應用服務器的七種武器

理解Java應用服務器的七種武器

編輯:JAVA編程入門知識

在意識到軟件架構的重要性後,應用服務器必然成為程序員的一件必不可少的"武器"。對應用服務器技術的透徹理解可以為程序員提供認識軟件架構的更大的空間,這種方式影響著軟件工程學文化。它接下來會用一些有用的工具來武裝現代的IT人,提升價值鏈。

本文標題中出現的數字七只是能夠讓我們同時記住的條目數量--我不希望給讀者的壓力過大。

第一種武器:信心——理解應用服務器並不困難

某些技術創造自己的傳奇的方法是很有趣的。我還記得自己在作為程序員時處理包含源代碼注釋(例如"不要放入此處"或者稍微文雅一點"此處危險")的產品。我們感覺非常復雜的代碼是不可管理的。應用服務器也成了相似的情況,人們毫無理由地恐懼的領域。在市場上,很多雇主把人們對於應用服務器的應用知識作為強制性的工作要求。實際上應用服務器並不是很復雜。例如,Sun微系統公司在自己的基於J2EE的應用服務器中包含了大量的文檔信息。你甚至於可以免費下載它,並在一個很基本的Windows XP專業版計算機上運行那些優秀的示例。

Sun的教程記述了大量的代碼示例,演示了J2EE和該公司的應用服務器產品的優勢和易用性。閱讀這些文檔是有價值的,因為它為我們洞察這種極其重要的軟件技術的工作情況提供了入口。Sun的競爭者還有BEA、IBM和開放源代碼應用服務器JBOSS。

BEA甚至於把應用服務器作為它的"透明計算"的第一步。它具有面向服務的架構的優點,在面向服務的架構中,我們可以利用舊的和新的應用程序來簡化不斷增長的敏捷型組織對服務的需求。BEA的觀點是可能出現一種情況:公司改變它們的IT系統和業務流程可以像從一個應用程序中剪切數據然後粘貼到另一個應用程序中那樣簡單。其要點在於這種努力是基於應用程序服務器技術的。

很明顯,應用服務器是成熟的軟件工業中的重要元素。它們內容豐富,並且依靠集中的應用程序管理,允許數據的集中存儲。這種技術是可以使用並且不難理解的。

第二種武器 平台性——應用服務器是一種軟件平台

應用服務器趨向於減少企業需要的中間件數量--因為它們是中間件!與包含了防火牆的Windows類似,應用服務器可能吸收一些現有的中間件產品所扮演的角色。這是因為應用服務器自身就是用於軟件部署以供多個客戶端使用的平台。在應用服務器中使用的軟件有截然不同的生命周期,包括:

· 開發者建立應用程序或組件

· 包裝成可部署的元素

· 部署在應用服務器平台上

· 被最終用戶使用

· 在再次部署中由開發者更新特性或修補

· 應用程序達到使用壽命後期的時候收回

在很多情況下,它與"正常的"應用程序軟件的管理方式是不同的。這一點對於多層分布式軟件系統尤其突出(在這種情況下客戶端用戶與後端服務器應用程序交互操作)。應用程序服務器與多層軟件應用程序套件之間最主要的區別在於,應用服務器提供了大量的軟件包裝支持。換句話說,應用服務器為很多領域(例如線程管理、數據庫連接、網絡訪問等等)提供了運行時(runtime)支持。應用服務器中的這些設施都是自由使用的,但是在傳統的軟件套件中,它們一般要求人們手動編寫代碼來實現。

簡單的說,應用服務器有效地分割了主機平台與應用程序軟件的業務邏輯。通過提供對軟件的大量支持,應用服務器技術允許軟件設計者和開發者將精力集中在解決自己特定領域的問題上。適當地使用應用服務器技術可以減少軟件開發的費用。

在上面的軟件生命周期中,我們把標准的應用服務器工具(例如基於ant的工具)當作專用工具來使用。其它的一些與J2EE應用服務器部分綁定的應用程序還包括:

· 管理控制台

· 部署工具

· 調試工具

· J2EE兼容性檢測程序

管理控制台用於管理應用服務器上執行的軟件,例如激活/不激活、列舉組件等等。部署工具用於為應用服務器環境准備軟件。調試工具用於輔助解決那些發生的問題。J2EE兼容性檢查對於新軟件的作者來說是非常重要的,因為J2EE組件與標准的Java類是不同的。

Sun的文檔表明應用服務器軟件產品的生產事務是可以在專家之間進行分工的。程序員編寫和測試源代碼,接著把這些源代碼傳遞給部署人員。部署人員准備並包裝軟件供我們在應用服務器上使用。在這個時候,軟件可能被傳遞回程序員以供調試和集成測試。另一組專家可以檢測該軟件的J2EE兼容性。其要點是一個或多個稱職人員可以執行這麼多不同的復雜的事務。

數據集中管理器對應用服務器下運行的應用程序擁有更大的控制權。這意味著企業中運行的軟件可以在同一個平台上集中地管理和部署。在某些方面,應用服務器技術使我們"後退"到了大型機時代的軟件部署情形。反對的觀點認為這種模型使客戶端不需要寄宿和執行大量的代碼,但是在客戶端上執行比在一個或多個應用服務器上執行的效率更高;同樣,由於帶寬的迅速擴大,帶寬的約束力也逐步縮小。
第三種武器 技術傳承——應用服務器是基於組件的

J2EE應用程序遵循廣泛采用的面向組件的方法。它們被分割成運行在客戶端或服務器上的應用程序。客戶端寄宿應用程序和applets,服務器寄宿Java小服務器程序、JavaServer頁面和企業級JavaBean(EJB)技術。

可以在應用服務器上部署的主要的組件文件類型有:Web檔案文件(WAR)和企業級jar(EAR)文件。客戶端應用程序都被打包成JAR文件。我們可以把組件准備好,在Sun應用服務器上部署它,而大多數准備工作是在向導的幫助下或使用工具(例如部署工具、asant和管理控制台等等)來自動地完成的。

應用服務器技術的面向組件的特性與軟件工程文化的趨勢是一致的。有趣的是,軟件架構的演化在描述給定架構的軟件元素的時候趨向於不使用組件這個單詞。作為代替的是,在某個組件不僅僅是運行時實體的時候,推薦使用元素來描述它。應用服務器技術是否需要更多的架構細節也是很有意思的。

第四種武器 團隊工作——應用服務器提供了軟件協同工作的能力

J2EE的根基之一是XML,它日益成為粘合各種應用程序的"膠水"。在網絡管理領域,由於XML允許我們簡單地定義服務並把它們轉換為軟件,從而顯得光芒耀眼。XML作為改善軟件(特別是寄宿在應用服務器上的軟件)之間協同工作能力的一種途徑,其重要性還會不斷增加。

J2EE還提供了對數據庫事務的支持。使用ATM取錢就是事務的一個例子。如果在事務的過程中出現電力中斷或網絡故障,你不希望帳號多次記入貸方,除非你中了彩票(哈哈)。因此,事務支持是應用服務器基礎構造的一個重要的元素,它在J2EE中占據著重要的位置。

第五種武器 想象力——應用服務器是高度抽象的

我經常在想,軟件從業人員提升價值鏈的最好辦法就是使用抽象事務。我們不是在分散的和有限的事務上孤獨地工作,而是找出不太明確的抽象事務。抽象事務的例子包括建立存儲備份策略、定義某個重要的應用程序特性的需求等等。

抽象事務是很大的挑戰,它強迫大腦分而治之。應用服務器為運行在它上面的軟件使用了一個相當抽象的模型。例如,J2EE允許你的軟件訪問後台的數據庫,用這種方法提供了抽象的支持。它同時還考慮資源情況,隱藏了特定數據源的復雜性。

第六種武器 獨立性——J2EE與Sun的應用服務器是獨立的、截然不同的

這是一個很基本的觀點:J2EE本質上是一個高級的API,但是它的確包含了一些在應用服務器環境之外運行部件。其中一個例子是XSLT,它允許我們把傳統的數據轉換為XML,反之亦然。

J2EE的重要性還在持續增長;有些軟件架構專家甚至於把J2EE作為21世紀軟件工程文化首要的改造部分。它與環球網在90年代改變軟件工程文化的情況類似--這也是花費精力了解J2EE和相關技術的另一個原因。更深一層的原因是微軟和Sun目前在讓它們的產品協同工作方面積極地合作。

第七種武器 發展——應用服務器:軟件未來之窗

應用服務器對企業中的軟件集中執行的能力是強大的、引人注目的。它可能使IT業對已部署的軟件的控制能力提高了一個很高的層次。當主要的軟件組件基於應用服務器的時候,我們可以應用體系結構方面的品質屬性,例如安全性、可修改性和可靠性。

這樣,J2EE和應用服務器技術無疑會成為軟件未來的橋梁。它還符合軟件架構專家和面向服務的架構典型。

結論

不要害怕應用服務器技術!即使很便宜的PC也可以寄宿高級的軟件套件(例如Sun的J2EE和它的應用服務器產品)。當然你也可以使用開放源代碼的。其要點是這種技術越來越流行,同時越來越易於使用。

通過使用這種技術,你將了解軟件工程文化的發展趨勢,並會看到某些重要工作的產物。每個人都在談論Web服務,但是都沒有使用和建立自己的例子那麼全面。即使企業級JavaBeans、Servlets和其它的J2EE技術

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved