Spring OSGi的整合
OSGi的強(qiáng)大還在于它的聲明式服務(wù)(DS-DeclarativeServices),乍一看,和Spring的依賴注入(DI- DependencyInjection)很相像,于是不免會想到OSGi是否會對Spring產(chǎn)生巨大的沖擊呢?其實這種擔(dān)心完全沒有必要,相反二者的結(jié)合反而會讓OSGi如虎添翼,強(qiáng)者更強(qiáng)。
51CTO編輯推薦:OSGi入門與實踐全攻略
Spring組織早在2006年已經(jīng)開始了OSGi的整合工作,由于OSGi獨特的類加載機(jī)制和一些其他的第三方類包不同,所以整合有一定難度進(jìn)展比較緩慢。類加載問題也將是我們在使用OSGi開發(fā)時遇到的最多的問題。
第一步先搞定Spring的jar包。據(jù)說Spring2.1會支持OSGi,為省點力氣我采用的是Spring2.1m3版,里面的jar包已經(jīng)開始支持OSGi,但類庫中沒有加入OSGi的整合類庫,比較郁悶。下載后的jar包需要修改一下里面的元數(shù)據(jù)文件MANIFEST.MF,找到Import-Package,將org.osgi.framework的版本修改為1.4.0,這個OSGi類庫在Eclipse3.3版本中提供有。然后在文件末尾添加DynamicImport-Package:*,免得調(diào)試的時候總找不到類定義。
這里我提一個建議:用Eclipse創(chuàng)建一個插件工程,將Spring的類庫導(dǎo)入,作為我們使用的Spring庫,而不是從官方網(wǎng)站下載的。這樣一者有助于我們理解OSGi的類加載機(jī)制,確定程序在運行時到底需要依賴那些類包,為什么依賴;二者有助于以后我們自己創(chuàng)建自己的插件。唯一的缺點就是需要不時的處理NoClassDefFoundError。
第二步搞定OSGi的整合類庫,先到http://www.springframework.org/osgi下載最新的Spring OSGi整合類庫,最新的版本是1.0M2。一共3個jar包:core、extender、io,然后分別打開jar包,修改 MANIFEST.MF文件。在文件中找到Import-Package,將引用的Spring版本修改為所使用的Spring版本,例如我使用的是 2.1。
第三步設(shè)置Eclipse插件環(huán)境,這一步比較麻煩。
首先添加和設(shè)置jar包。將Spring OSGi的3個jar包,放到Eclipse安裝目錄的plugins目錄下,為更好的識別和修改,建議采用Eclipse插件的link機(jī)制,單獨建一個目錄來放我們的測試jar 包。另外還需要支持Spring的jar包(下載Spring2.1時自帶的),包括:asm,backport-util- concurrent,cglib-nodep,commons-attributes,commons-collections,aspectj,由于我在做OSGi、Spring和Hibernate的整合,所以有些是支持Hibernate的。好了現(xiàn)在該啟動Eclipse,打開Windows->Preferences->Plug- inDevelopment->TargetPlatform,在右側(cè)會看到Eclipse加載的所有插件包,選中我們需要的(除了上面提到的之外):org.eclipse.osgi,org.eclipse.osgi.util,org.eclipse.equinox.log(如果沒有這個,需要到Eclipse官網(wǎng)下載Equinox的jar包)。
然后打開Run->OSGiFramework->Bundles,創(chuàng)建一個運行環(huán)境,把我們上一步添加的jar包選中,特別將 spring osgi-extender的插件的啟動級別改為2?,F(xiàn)在來運行一下,在Console窗口的命令提示符(osgi>)下,輸入 ss,就可以看到各個Bundle的狀態(tài);輸入log可以看到啟動的日志。隨意輸入其它非OSGi命令的字符都可以看到命令幫助文檔,這點可以測試一下。
如果所有的Bundles都啟動了,沒有報錯,那就表明我們的配置沒有什么大的問題。但不代表一切正常,因為Bundle啟動時不會對可選擇的類庫導(dǎo)入進(jìn)行檢查,雖然啟動了但卻不能用,而且沒有任何重要信息提示,這是后來郁悶我很久的重要原因。這時我們就需要用到插件調(diào)試模式了(不是指Run-Debug 的調(diào)試),打開Run->OSGiFramework->Arguments,在Programarguments窗口的參數(shù)最后面加上"-debug"就可以打開調(diào)試模式。先別高興,這只是第一步。檢查Eclipse目錄下是否有一個“.options”文件,如果沒有,就到 plugins目錄下找org.eclipse.osgi_$version.jar,將這個jar包中的“.options”文件copy一份放到 Eclipse目錄下。打開這個文件就可以看到好多跟debug相關(guān)的配置,把org.eclipse.osgi/debug的配置改成true,就可以了。如果想看更多的debug信息,可以自己決定修改其余的配置。
然后再來運行一下,Console居然出來了無數(shù)行的插件調(diào)試信息,有點頭大,在參數(shù)中去掉“-debug”它們就銷聲匿跡了。
關(guān)于Eclipse的插件配置還有好多,只是由于手頭缺少資料,也沒有嘗試。
【編輯推薦】