《電子技術(shù)應(yīng)用》
您所在的位置:首頁(yè) > 其他 > 業(yè)界動(dòng)態(tài) > J2EE應(yīng)用服務(wù)器與JBuilder集成的實(shí)現(xiàn)

J2EE應(yīng)用服務(wù)器與JBuilder集成的實(shí)現(xiàn)

2008-12-12
作者:楊光,雷益鵬

背景知識(shí)?

??? 對(duì)于廣大的J2EE應(yīng)用開(kāi)發(fā)人員來(lái)說(shuō),一個(gè)強(qiáng)大而高效的Java開(kāi)發(fā)環(huán)境是必不可少的。JBuilder是一個(gè)優(yōu)秀的JAVA 集成開(kāi)發(fā)環(huán)境,它能夠集成Weblogic, WebSphere,Borland Enterprise Server等應(yīng)用服務(wù)器" title="應(yīng)用服務(wù)器">應(yīng)用服務(wù)器,使開(kāi)發(fā)人員可以快速開(kāi)發(fā)和分發(fā)應(yīng)用程序到這些J2EE平臺(tái)應(yīng)用服務(wù)器。?

??? 除了目前JBuilder支持的應(yīng)用服務(wù)器外,還有一些受用戶(hù)喜歡,并正在使用的應(yīng)用服務(wù)器產(chǎn)品。對(duì)于習(xí)慣于使用JBuilder的開(kāi)發(fā)人員來(lái)說(shuō),他們特別希望這些應(yīng)用服務(wù)器也能被JBuilder所支持,以便在開(kāi)發(fā)過(guò)程中應(yīng)用JBuilder的強(qiáng)大功能。因此,將特定的應(yīng)用服務(wù)器與JBuilder集成,是一件非常有意義的事情。?

??? 為此,我們著手實(shí)施了這項(xiàng)工作,通過(guò)開(kāi)發(fā)TongWebOpenTools插件,成功地將國(guó)產(chǎn)應(yīng)用服務(wù)器TongWeb集成到JBuilder開(kāi)發(fā)環(huán)境中,現(xiàn)將實(shí)現(xiàn)方法描述如下。

JBuilder的Open Tools框架?

??? 首先介紹一下JBuilder提供的一種允許第三方" title="第三方">第三方擴(kuò)展IDE的機(jī)制,即Open Tools框架,JBuilder同時(shí)提供了實(shí)現(xiàn)該框架的接口 — OpenTools API。

1.Open Tools框架

??? 在OpenTools 框架中,能對(duì)JBuilder的很多功能進(jìn)行擴(kuò)展,對(duì)J2EE應(yīng)用服務(wù)器支持的擴(kuò)展就是其中之一。在JBuilder7.0以前的版本中,在對(duì)J2EE應(yīng)用服務(wù)器支持的擴(kuò)展方面,提供了AppServer機(jī)制,我們可以利用這種機(jī)制將第三方的J2EE應(yīng)用服務(wù)器集成到JBuilder中,達(dá)到擴(kuò)展JBuilder所能支持的應(yīng)用服務(wù)器的目的。在JBuilder7.0/8.0版本中,已經(jīng)不采用AppServer機(jī)制了,而是提供了Server Plugin機(jī)制。為了將已經(jīng)在7.0以前版本中擴(kuò)展的應(yīng)用服務(wù)器繼承過(guò)來(lái),JBuilder還提供了一種Legacy機(jī)制,可以將基于以前版本的JBuilder的應(yīng)用服務(wù)器擴(kuò)展集成到7.0/8.0版本中。此外,JBuilder還提供了一種Server Configuration機(jī)制,支持對(duì)應(yīng)用服務(wù)器進(jìn)行配置,并保存配置。

??? 針對(duì)目前使用最廣泛的JBuilder7.0及以上版本,為了實(shí)現(xiàn)對(duì)一個(gè)新的第三方J2EE應(yīng)用服務(wù)器的支持,應(yīng)該采用Server Plugin和Server Configuration機(jī)制。因此,對(duì)這兩種機(jī)制,在這里有必要簡(jiǎn)要介紹一下。

(1)Server Plugin機(jī)制?

?????? Server Plugin主要涉及三個(gè)方面的內(nèi)容,Server,Service,Plugin。Server指的是一些特定版本的應(yīng)用服務(wù)器,例如Borland Enterprise Server 5.0,Tomcat 4.0,WebLogic6.1等。Service是應(yīng)用服務(wù)器所支持的特性,例如EJB, web application (JSP and Servlet), JMS, deployment等。Plugin指的是一些classes,通過(guò)這些classes,可以使Server和Service在JBuilder中注冊(cè),以便能在JBuilder的集成開(kāi)發(fā)環(huán)境中被使用。因此,Server Plugin機(jī)制主要包含了Server、Services和ServerLanucher API。類(lèi)圖如下:

圖 1 Server Plugin機(jī)制類(lèi)圖

??? 每個(gè)Server類(lèi)的子類(lèi)" title="子類(lèi)">子類(lèi)實(shí)現(xiàn)都代表一個(gè)應(yīng)用服務(wù)器,該子類(lèi)可以根據(jù)情況包含不同的Services。支持的Services包括:ClientJarService、EjbService、JspServletService、DeployService等等。

????在JBuilder啟動(dòng)時(shí),Server類(lèi)的子類(lèi)能夠通過(guò)工具類(lèi)ServerManager將自己及自己支持的Services注冊(cè)到JBuilder中。該注冊(cè)過(guò)程位于必須實(shí)現(xiàn)的方法initOpenTool()中。方法initOpenTool()是一個(gè)很特殊的方法,它不是由任何接口或虛類(lèi)指定,但任何想接入JBuilder中的插件都必須提供該方法來(lái)將自己注冊(cè)到JBuilder中。JBuilder 將根據(jù)是否提供該方法來(lái)自動(dòng)發(fā)現(xiàn)第三方提供的插件,并自動(dòng)將其按插件方式載入。

????ServerLanucher則是支持Server 啟動(dòng)的類(lèi),能提供Server 啟動(dòng)所需的各種信息,并且提供了在Server啟動(dòng)和停止的各個(gè)階段插入代碼的接口。它由Server來(lái)創(chuàng)建。

(2)Server Configuration機(jī)制?

????在JBuilder中使用任何一個(gè)應(yīng)用服務(wù)器,都必須先進(jìn)行配置。JBuilder啟動(dòng)后,通過(guò)JBuilder菜單中的Tools->Configure Servers,可打開(kāi)Configure Servers對(duì)話(huà)框。在該對(duì)話(huà)框中可以看到,左邊是Server列表欄,右邊是Server的常規(guī)配置信息和定制的配置信息。當(dāng)一個(gè)Server的OpenTool通過(guò)ServerManager實(shí)現(xiàn)了注冊(cè),這個(gè)Server將出現(xiàn)在Server列表欄中。選擇Server,并對(duì)Server進(jìn)行配置后,注冊(cè)的Server就可以在JBuilder中使用了。這一配置機(jī)制就是JBuilder提供的Server Configuration機(jī)制。該機(jī)制能將配置的信息保存起來(lái),下次啟動(dòng)JBuilder時(shí),它就能讀取先前的配置,并根據(jù)該配置查找類(lèi)庫(kù)。如果找不到匹配的Server庫(kù)(比如已經(jīng)刪除),則該Server在對(duì)話(huà)框的Server列表欄中顯示為紅色。

圖 2 Server配置界面的類(lèi)圖

2.? OpenTools API

??? 在OpenTools框架中,和集成J2EE應(yīng)用服務(wù)器相關(guān)的API都在包com.borland.jbuilder和包com.borland.primetime中,下面

我就其中主要的包進(jìn)行一下介紹。

(1)?????? com.borland.jbuilder中的包

com.borland.jbuilder.server: 主要用于ServerServices的注冊(cè)。

com.borland.jbuilder.enterprise.ejb: 主要用于支持JBuilder7.0以前版本的AppServer機(jī)制,還用于生成選定的應(yīng)用服務(wù)器的部署描述符" title="描述符">描述符。

com.borland.jbuilder.enterprise: 主要用于ServerJDK設(shè)置。

com.borland.jbuilder.runtime.servlet:主要用于Servlet Service的實(shí)現(xiàn)。

(2)?????? com.borland.primetime中的包

com.borland.primetime.node: 主要用于對(duì)項(xiàng)目和文件節(jié)點(diǎn)的操作。

com.borland.primetime.properties: 主要用于屬性設(shè)置。

com.borland.primetime.ide: 主要用于實(shí)現(xiàn)圖形界面。

TongWeb Open Tools的實(shí)現(xiàn)
??? TongWeb Open Tools是為了將應(yīng)用服務(wù)器TongWeb集成到JBuilder而開(kāi)發(fā)的,它是JBuilder OpenTools框架的一個(gè)具體實(shí)現(xiàn)。目前,已經(jīng)完全支持在JBuilder中基于TongWeb 應(yīng)用服務(wù)器進(jìn)行EJB和Jsp/Servlet的開(kāi)發(fā)、部署、運(yùn)行以及動(dòng)態(tài)調(diào)試。
??? 為了實(shí)現(xiàn)上述功能,我們需要解決下列問(wèn)題:
1.?Server管理,包括Server的注冊(cè)載入,Server的啟動(dòng)等
2.?Ejb部署描述符的生成
3.?Jsp/Servlet 的編譯
4.?動(dòng)態(tài)部署
5.?動(dòng)態(tài)調(diào)試
6.?配置管理,包括Project Properties,Configure Servers等
??? TongWeb Open Tools可以劃分為6個(gè)模塊,即Server模塊,Generic deploy code(部署代碼生成" title="代碼生成">代碼生成)模塊,JSP/Servlet Compiler模塊,Deploy(動(dòng)態(tài)部署)模塊,Configure模塊和動(dòng)態(tài)調(diào)試模塊。各個(gè)模塊的關(guān)系圖如下, 其中白色為外部系統(tǒng)。


????????????????????????????????? ?圖 3 TongWeb Open Tools模塊關(guān)系圖
1. Server模塊
??? Server模塊負(fù)責(zé)注冊(cè)Server及Server提供的各種服務(wù)(services)、提供Server啟動(dòng)時(shí)所需的各種參數(shù)。
??? Server模塊在JBuilder啟動(dòng)時(shí)由JBuilder Opentools 框架提供的ServerManager注冊(cè)到JBuilder中。
2.?Generic deploy code(部署代碼生成)模塊
??? 部署代碼生成模塊負(fù)責(zé)生成TongWeb EJB部署描述符(包括ejb-jar.xml、teas-ejb-jar.xml)和部署代碼(包括stub/skeleton及實(shí)體Bean的O/R映射代碼jorm),并將所有生成的代碼和EJB本身打包成可部署到TongWeb3.4上的EJB jar包。
在JBuilder中,EJB部署描述符的生成原理是:在創(chuàng)建EJB工程及設(shè)計(jì)EJB的過(guò)程中,JBuilder將自動(dòng)生成Jbuilder特定的部署描述符,然后JBuilder將JBuilder特定的部署描述符轉(zhuǎn)換成選定的應(yīng)用服務(wù)器的部署描述符。該轉(zhuǎn)換是針對(duì)選定的應(yīng)用服務(wù)器特定的部署描述符而言,對(duì)于J2EE標(biāo)準(zhǔn)的ejb-jar.xml則不需要轉(zhuǎn)換。這個(gè)轉(zhuǎn)換工作,要由選定的應(yīng)用服務(wù)器的Opentools來(lái)實(shí)現(xiàn)。因此,TongWeb Open Tools中,我們?cè)O(shè)計(jì)和實(shí)現(xiàn)了一個(gè)特定的類(lèi)來(lái)完成這個(gè)轉(zhuǎn)換。
??? 對(duì)于部署代碼的生成和最終的打包,則是調(diào)用了TongWeb服務(wù)器的工具GenIC來(lái)完成。
3.?JSP/Servlet Compiler模塊
??? JSP/Servlet Compiler模塊負(fù)責(zé)對(duì)JSP/Servlet的編譯,并將所有生成的代碼打成war包。為了能實(shí)現(xiàn)對(duì)JSP/Servlet的編譯,并生成可部署的war包,需要通過(guò)對(duì)OpenTools API的JspCompiler和JspSourceBridge進(jìn)行擴(kuò)展。
4.?Deploy(動(dòng)態(tài)部署)模塊
??? 通過(guò)調(diào)用TongWeb服務(wù)器的工具TeasAdm,動(dòng)態(tài)部署模塊實(shí)現(xiàn)了將EJB動(dòng)態(tài)的部署到運(yùn)行中的TongWeb3.4服務(wù)器,重新部署,取消部署,列出可部署的jar包等功能。
5.?Configure模塊
??? Configure模塊是用戶(hù)配置上述幾個(gè)模塊所需參數(shù)的圖形界面。在JBuilder中,參數(shù)的配置和對(duì)參數(shù)的使用是分離的。為了實(shí)現(xiàn)這種分離,它通過(guò)靜態(tài)類(lèi)PropertyGroup及其子類(lèi)來(lái)進(jìn)行參數(shù)的存儲(chǔ)工作。配置好的參數(shù)寫(xiě)入靜態(tài)類(lèi)PropertyGroup中,當(dāng)其它模塊需要使用這些參數(shù)時(shí)就從靜態(tài)類(lèi)PropertyGroup中獲取。靜態(tài)類(lèi)PropertyGroup從作用上看類(lèi)似一個(gè)配置文件,但它是寫(xiě)在內(nèi)存中的,速度較快。
使用TongWeb Open Tools
??? TongWeb Open Tools的最終產(chǎn)品是一個(gè)TongWebOpenTool.jar文件,只需要將這個(gè)文件拷貝到 libext目錄下,就完成了產(chǎn)品的安裝。
??? 完成產(chǎn)品安裝后,在JBuilder中就可以輕松的開(kāi)發(fā),部署應(yīng)用程序到TongWeb3.4應(yīng)用服務(wù)器上了,下面將用幾張圖來(lái)簡(jiǎn)要描述安裝了TongWeb Open Tools插件的JBuilder對(duì)TongWeb3.4應(yīng)用服務(wù)器的支持。
(1)?配置TongWeb應(yīng)用服務(wù)器
??? 當(dāng)TongWeb Open Tools安裝后,啟動(dòng)JBuilder后,選擇JBuilder菜單中的Tools->Configure Servers,可以看到TongWeb 應(yīng)用服務(wù)器已經(jīng)出現(xiàn)在左側(cè)的服務(wù)器列表中了,選則TongWeb應(yīng)用服務(wù)器后,就可以對(duì)它進(jìn)行配置。

???????????????????????????????????????? 圖 4 配置服務(wù)器
(1) 部署EJB
??? 選擇菜單中的deploy,對(duì)?EJB進(jìn)行部署,在JBuilder的控制臺(tái)上會(huì)顯示提示信息,當(dāng)部署成功,將顯示Succeeded: Dedeploy --- xxx.jar。

圖 5部署EJB?

?

結(jié)束語(yǔ)?

??? 如何向用戶(hù)提供方便高效的開(kāi)發(fā)工具,是國(guó)產(chǎn)應(yīng)用服務(wù)器廠商面臨的一個(gè)重要問(wèn)題。對(duì)TongWeb來(lái)說(shuō),通過(guò)開(kāi)發(fā)TongWeb Open Tools,使JBuilder支持面向TongWeb的全過(guò)程開(kāi)發(fā),既充分利用了JBuilder的強(qiáng)大功能,又解決了國(guó)產(chǎn)應(yīng)用服務(wù)器的開(kāi)發(fā)工具支持問(wèn)題,不失為一種比較好的策略。

參考文獻(xiàn)?

1. 《Developing OpenTools》 http://www.borland.com/?


?

本站內(nèi)容除特別聲明的原創(chuàng)文章之外,轉(zhuǎn)載內(nèi)容只為傳遞更多信息,并不代表本網(wǎng)站贊同其觀點(diǎn)。轉(zhuǎn)載的所有的文章、圖片、音/視頻文件等資料的版權(quán)歸版權(quán)所有權(quán)人所有。本站采用的非本站原創(chuàng)文章及圖片等內(nèi)容無(wú)法一一聯(lián)系確認(rèn)版權(quán)者。如涉及作品內(nèi)容、版權(quán)和其它問(wèn)題,請(qǐng)及時(shí)通過(guò)電子郵件或電話(huà)通知我們,以便迅速采取適當(dāng)措施,避免給雙方造成不必要的經(jīng)濟(jì)損失。聯(lián)系電話(huà):010-82306118;郵箱:aet@chinaaet.com。