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