??? Avalon是以一定數(shù)量的為了提高代碼質量、重用度和可維護性的核心的編程習慣和設計模式作為基礎的。例如:面向服務編程(Service oriented Programming)、反向控制(Inversion of Control)和分離考慮(Separation of Concerns)等作為一個構建服務器端組件(server-side components)的框架。本文對如何使用Avalon框架編程作了簡要介紹,希望能對進行服務器端開發(fā)的技術人員一些啟示。
1. Avalon的重要子項目
??? 為了讓你更好的理解Avalon框架,下面簡要的介紹以下它的重要子項目從而使你對Avalon整體框架有一個初步的認識。
1.1 Framework
??? Avalon Framework是Avalon大傘下的所有其它項目的基礎。它定義了接口、契約(contracts)和Avalon的缺省實現(xiàn)。Framework將大部分工作置于其中,因此也是最為成熟的項目。
1.2 Excalibur
??? Avalon Excalibur是一組服務器端組件,您可以在自己的項目中使用它們。它包括了池(pooling)的實現(xiàn)、數(shù)據(jù)庫連接管理和其它一些組件管理的實現(xiàn)。
1.3 Phoenix
??? Avalon Phoenix是服務器核心,它管理服務(Service,實現(xiàn)為服務器端組件,稱作Block)的發(fā)布和執(zhí)行。
1.4 Cornerstone
??? Avalon Cornerstone是一組Block或服務,這些Block可以布署在Phoenix環(huán)境中。這些Block包括了socket管理和Block之間的任務調度。
2.Avalon的原理和模式
?? ?Avalon框架中運用了許多新的編程觀點和理念,下面一一的作介紹。
2.1反向控制(Inversion of Control,IOC)
??? 反向控制的概念是指組件總是由外部進行管理的。這個短語是由Brian Foote在他的一篇論文中最先使用的(參看http://www.laputan.org/drc/drc.html)。組件所需的一切通過Contexts、Configurations和Loggers的方式賦予組件。實際上,組件生命周期中的每個階段都是由創(chuàng)建組件的代碼所控制的。當您使用這種模式時,就實現(xiàn)了一種組件與您的系統(tǒng)安全交互的方法
2.?2面向組件的編程(Component Oriented Programming ,COP)
??? 面向組件的編程是把系統(tǒng)分割成一些組件或設施的一種思想。每種設施都有一個工作接口和圍繞該接口的契約。這種方式允許容易地更換組件的實例,同時不影響系統(tǒng)其它部分的代碼。面向對象" title="面向對象">面向對象編程(Object Oriented Programming ,OOP)和COP的主要區(qū)別在于集成的層次。COP系統(tǒng)的復雜性更容易管理,這得益于類之間更少的相互依賴。這提高了代碼重用的程度。
??? COP的主要好處之一是修改項目代碼的一些部分不會破壞整個系統(tǒng)。另一個好處是可以有某組件的多種實現(xiàn),并可以在運行時刻進行選擇。
2.3面向服務的編程(Service Oriented Programming ,SOP)
??? 面向服務的編程的思想是把系統(tǒng)劃分為由系統(tǒng)提供的一些服務。
??? Avalon的 Phoenix把每一種要提供的設施看作是一項服務,由特定接口和相關契約組成。服務的實現(xiàn)被稱為Block。一個服務器程序是由多種服務組成的,認識這一點很重要。以郵件服務器為例,它會有協(xié)議處理服務、認證和授權服務、管理服務和核心郵件處理服務等。
??? Avalon的 Cornerstone提供了一些低層的服務,您可以在自己的系統(tǒng)中加以利用。提供的服務包括連接管理、socket管理、參與者/角色管理和調度等。我們在這里介紹到服務是因為它與把我們的假定系統(tǒng)分解為不同設施的過程有關。
3.用Avalon Phoenix開發(fā)服務器應用
??? Phoenix 是在Avalon Framework 之上的微內核設計和實現(xiàn)。它提供了一些工具用來管理服務器應用環(huán)境。這些工具包括日志管理,類裝載(classloading),線程管理和安全。它的后續(xù)版本將有條件的支持額外工具,例如:中央服務管理" title="服務管理">服務管理,服務池和其他一些縮短產品進入市場時間的工具。Phoenix的API定義了匯集服務器組件和創(chuàng)建服務器的標準方法。
??? Phoenix默認的管理工具或者稱之為引擎是利用Avalon Framework及基本設計原理和編程習慣建造而成的。JMX MBean 服務是Phoenix分布的一部分,用于管理Phoenix服務器內核及Phoenix應用程序" title="應用程序">應用程序。客戶端" title="客戶端">客戶端不能通過RMI 適應器連接到MBean。
Phoenix應用程序稱為SARs(服務器檔案),它被配置在一個預配置的目錄內。在運行SARs檔案以前,Phoenix核心可以解包并驗證檔案的內容
?? 下面介紹一個實際入門的類似Hello World的例子,該工程名為sckServer。進行開發(fā)前請首先到http://avalon.apache.org/ 下載所需的jar。工程是用ant組織的,該工程的目錄結構如下圖所示:
3.1 第一步:定義服務
??? 在Avalon中,每一個組件一被選中或者由角色重新得到,它就和一個角色(role)相關聯(lián)的。對于我們所定義的sckService服務,所有的角色接口如下:
package org.my;
public interface sckService
{ ? String ROLE="org.my.sckService";
public void postMessage(String msg);
}
3.2 第二步:實現(xiàn)服務
??? 在Server類中實現(xiàn)了sckService接口。Avalon Framework則實現(xiàn)了幾個生命周期以及線程接口的定義。盡管Avalon實現(xiàn)這些是不可見的,但運用的Scheduler和SocketManager組件卻是Conerstone的一部分。
?//導入一些必要的包。
public class Server extends AbstractLogEnabled
implements sckService, Block, Contextualizable, Composable, Configurable, Initializable, ConnectionHandlerFactory, ConnectionHandler
{? static protected Configuration CONFIGURATION;
?? protected SocketManager?????? m_socketManager;
?? protected ConnectionManager?? m_connectionManager;
?? protected BlockContext??????? m_context;
?? protected InetAddress???????? m_bindTo;
?? protected int???????????????? m_port;
?? public ConnectionHandler createConnectionHandler() throws Exception
{??? final Server handler = new Server();
?????? setupLogger( handler );
?????? return handler;
?? }
?? public void initialize() throws Exception
{? ……
? }
public void compose( final ComponentManager componentManager ) throws ComponentException
{? getLogger().info("Server.compose()");
??????? m_socketManager = (SocketManager)componentManager.lookup( SocketManager.ROLE );
??????? m_connectionManager = (ConnectionManager)componentManager.lookup( ConnectionManager.ROLE );
??? }
public void configure( final Configuration configuration ) throws ConfigurationException
{? ……
}
public void contextualize( final Context context )
{? m_context = (BlockContext)context;
??? }
public void handleConnection( final Socket socket ) throws IOException
{? DataInputStream is = new DataInputStream(socket.getInputStream());
??????? OutputStream os = new DataOutputStream(socket.getOutputStream());
??? }
public void releaseConnectionHandler( ConnectionHandler connectionHandler )
{ }
public void postMessage( String fromUsername)
{?? ……
}
}
3.3第三步:配置描述文件
??? 由于篇幅所限,具體如何配置請參看http://avalon.apache.org/phoenix/ 可獲得十分詳細得信息。
3.?4打包為SAR文件
??? 應用程序必須打包為SAR文件,Phoenix才可以讀取。SAR文件中必須包括assembly.xml;config.xml和environment.xml三個配置文件。
3.5配置系統(tǒng)
??? 將打好得sckServer.sar文件放置在phoenix的apps目錄下,當phoenix啟動時它會自動讀取。
4 結束語
??? 中國互聯(lián)網絡信息中心(CNNIC)《中國互聯(lián)網絡發(fā)展狀況" title="發(fā)展狀況">發(fā)展狀況統(tǒng)計報告》表明,中國網民已經從1997年1月的62萬人增至2003年1月的5910萬人,另外我國上網計算機數(shù)、域名數(shù)、網站數(shù)等參數(shù)都有了較大的增長。互聯(lián)網令人難以置信的飛速發(fā)展,帶來了全新的生活、工作和學習方式。有網絡就不可能沒有服務,因而服務器端軟件開發(fā)已經成為十分重要的話題。Avalon以其自身的優(yōu)勢必會引起世人的矚目。由于篇幅所限,還有很多的內容不能一一介紹深表遺憾。
參考文獻:
[1] http://avalon.apache.org ,Avalon官方網站
[2] http://www.oreillynet.com ,Oreilly’s 主頁
[3] http://www-900.ibm.com/developerWorks/cn ,IBM中文開發(fā)者論壇