版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、基于j2ee在分布式環(huán)境下的底層結(jié)構(gòu)的自動(dòng)動(dòng)態(tài)配置的應(yīng)用 anatoly akkerman, alexander totok, and vijay karamcheti摘要:為了實(shí)現(xiàn)廣域網(wǎng)中符合工業(yè)標(biāo)準(zhǔn)基于組件的應(yīng)用程序中動(dòng)態(tài)的可適應(yīng)性,我們需要一種框架來(lái)在這樣的環(huán)境里自動(dòng)化地配置j2ee 應(yīng)用程序。這種需要對(duì)于哪怕在單一的應(yīng)用程序服務(wù)器上嘗試部署j2ee應(yīng)用的人來(lái)說(shuō)也顯而易見(jiàn),這種任務(wù)設(shè)計(jì)到大量的系統(tǒng)服務(wù)和應(yīng)用組件的配置。關(guān)鍵詞:j2ee;動(dòng)態(tài)配置;分布式;組件;1 前言近幾年,我們已經(jīng)看到基于組件的企業(yè)應(yīng)用開(kāi)發(fā)的顯著增加。這種應(yīng)用程序通常被部署在公司的內(nèi)部網(wǎng)或者是因特網(wǎng)上,以高事務(wù)容量,大
2、量的用戶和覆蓋范圍廣的訪問(wèn)為特征,它通常會(huì)被部署在中央?yún)^(qū)域,采用服務(wù)器集群來(lái)均衡負(fù)載從而支持用戶下載。但是這種平均負(fù)荷的方法被證明只對(duì)減少應(yīng)用轉(zhuǎn)發(fā)的用戶可以察覺(jué)的反應(yīng)時(shí)間有效,而對(duì)于減少網(wǎng)絡(luò)方面的延遲作用不大,垂直分割(例如運(yùn)行網(wǎng)絡(luò)層和事務(wù)層在不同的虛擬機(jī))被用于錯(cuò)誤分離和均衡負(fù)荷,但是它是不符合實(shí)際的由于遠(yuǎn)程調(diào)運(yùn)的大量使用顯著地增加了運(yùn)行時(shí)時(shí)間。最近的著作已經(jīng)表明在廣域網(wǎng)中利用垂直負(fù)荷而不引起前面所述的超時(shí)問(wèn)題的可行性。那非研究的主要結(jié)論可以概括如下:(1) 應(yīng)用合適的應(yīng)用程序,在廣域網(wǎng)中的垂直負(fù)荷可以察覺(jué)的延遲。(2) 廣域垂直層需要復(fù)制應(yīng)用層組件而且需要維持和原組件間的一致性。(3) 新
3、加的復(fù)制組件可以被動(dòng)態(tài)配置以滿足新的需要。(4) 事實(shí)上,不同的復(fù)制組件可能會(huì)根據(jù)應(yīng)用不同的方式實(shí)現(xiàn)相組件。(5) 新的請(qǐng)求路徑可以復(fù)用先前的組件配置路徑。應(yīng)用智能監(jiān)視和人工智能規(guī)劃方法再結(jié)合那個(gè)研究得出的結(jié)論,我們看到通過(guò)動(dòng)態(tài)布置基于動(dòng)態(tài)監(jiān)視的額外的應(yīng)用組件,在廣域網(wǎng)中符合工業(yè)標(biāo)準(zhǔn)基于組件的應(yīng)用程序中動(dòng)態(tài)的可適應(yīng)性是可以實(shí)現(xiàn)的。然而,為了實(shí)現(xiàn)這種動(dòng)態(tài)可適性,我們需要一種框架來(lái)在這樣的環(huán)境里自動(dòng)化地配置j2ee 應(yīng)用程序。這種需要對(duì)于哪怕在單一的應(yīng)用程序服務(wù)器上嘗試布置j2ee應(yīng)用的人來(lái)說(shuō)也顯而易見(jiàn),這種任務(wù)設(shè)計(jì)到大量的系統(tǒng)服務(wù)和應(yīng)用組件的配置。例如你必須在配置和部署應(yīng)用組件前先建立jdbc數(shù)
4、據(jù)源,設(shè)立消息目的地和資源適配器。在需要跨越多個(gè)節(jié)點(diǎn)服務(wù)器的廣域網(wǎng)配置中,這將更加復(fù)雜,因?yàn)楦嗟谋憷麅?nèi)部節(jié)點(diǎn)通信的系統(tǒng)服務(wù)需要配置和啟動(dòng),而且多種配置數(shù)據(jù)比如ip地址,端口號(hào),jndi名字和其他的數(shù)據(jù)在多個(gè)節(jié)點(diǎn)的配置文件中必須維持一致性。這種分布式配置框架必須滿足:(1) 聲明內(nèi)部組件一致性規(guī)范和定義它對(duì)組件配置部署的影響。(2) 聲明應(yīng)用程序組件對(duì)應(yīng)用服務(wù)器,以及它們的配置和部署的依賴性。(3) 提供簡(jiǎn)單但可表達(dá)的抽象方法去控制通過(guò)部署和拆卸組件獲得的適用性。(4) 能夠復(fù)用服務(wù)和組件從而高效的利用網(wǎng)路節(jié)點(diǎn)資源。(5) 提供上述便利而不會(huì)增加應(yīng)用程序員的設(shè)計(jì)負(fù)擔(dān)。在本論文中,我們提出自動(dòng)動(dòng)
5、態(tài)部署j2ee應(yīng)用程序的框架涉及了上面的所有問(wèn)題,這種框架為組件定義了結(jié)構(gòu)描述語(yǔ)言,鏈接說(shuō)明和集合。這種組件說(shuō)明語(yǔ)言用來(lái)描述應(yīng)用程序組件和鏈接,它使得應(yīng)用組件與系統(tǒng)組件中清晰的分開(kāi)。一種靈活的系統(tǒng)類型用來(lái)定義組件接口和端口的兼容性。一種為配置組件屬性而開(kāi)發(fā)的定義和表述語(yǔ)言允許內(nèi)部組件間獨(dú)立的規(guī)范和組件間屬性的繼承。組件集合語(yǔ)言允許先前定義的復(fù)制的組件通過(guò)連接合適的端口集合到應(yīng)用路徑,連接時(shí)通過(guò)鏈接復(fù)制對(duì)象和具體把這些復(fù)制組件映射到目標(biāo)應(yīng)用服務(wù)器節(jié)點(diǎn)。組件配置過(guò)程評(píng)估了應(yīng)用程序路徑的正確性,確認(rèn)在系統(tǒng)組件上的應(yīng)用組件的獨(dú)立性和完成復(fù)制組件的部署。根據(jù)這些配置使先前部署的復(fù)制組件在新的路徑中得以匹
6、配和復(fù)用的努力正在做出。我們把這種架構(gòu)作為jboss開(kāi)源java應(yīng)用服務(wù)器的一部分加以實(shí)現(xiàn),在幾個(gè)j2ee樣本程序比如java petstore,,rub和 tpc_w_nyu中進(jìn)行測(cè)試。這種架構(gòu)實(shí)現(xiàn)利用了jboss的可擴(kuò)展的微內(nèi)核結(jié)構(gòu),基于jmx規(guī)范。jboss的組件結(jié)構(gòu)允許根據(jù)部署應(yīng)用程序的需要增加服務(wù)配置。我們相信通過(guò)動(dòng)態(tài)部署和拆卸系統(tǒng)服務(wù)來(lái)重構(gòu)應(yīng)用服務(wù)器對(duì)構(gòu)建高效資源框架的動(dòng)態(tài)分布部署的j2ee應(yīng)用程序來(lái)說(shuō)是非常必要的。本文如下部分是這樣組織的。第2部分提供了必要的背景以理解和研究有關(guān)的j2ee組件技術(shù)規(guī)范。第3部分對(duì)這種架構(gòu)給出了一般性的描述。第4部分更深入的描述了有關(guān)這種架構(gòu)特別重
7、要的和有趣的內(nèi)部機(jī)制。第五部分描述了如何實(shí)現(xiàn)這種架構(gòu),相關(guān)聯(lián)的工作將在第六部分介紹。2 j2ee背景知識(shí)2.1 介紹組件框架。組件框架是一種中間件系統(tǒng),它支持遵守一定標(biāo)準(zhǔn)的有不同組件構(gòu)成的應(yīng)用程序。應(yīng)用組件被塞入這種確立它們運(yùn)行環(huán)境和規(guī)定它們交互的框架中。這通常是通過(guò)容器,組件持有者來(lái)實(shí)現(xiàn)的。這種容器也提供通常需要的功能以實(shí)現(xiàn)命名,安全性,事務(wù),和持久性!組件框架為組件的執(zhí)行提供了一個(gè)集成的環(huán)境,因此顯著的減少了在設(shè)計(jì),實(shí)現(xiàn),部署和維護(hù)應(yīng)用程序時(shí)工作?,F(xiàn)在工業(yè)上的組件框架標(biāo)準(zhǔn)以對(duì)象管理組的corba組件模型, sun 公司的java 2 platform j企業(yè)版j2ee和微軟公司的.net標(biāo)
8、準(zhǔn),其中在企業(yè)里應(yīng)用最為廣泛的組件框架是2eee。j2ee. j2ee是開(kāi)發(fā)多層企業(yè)應(yīng)用java程序的綜合性的標(biāo)準(zhǔn)。j2ee規(guī)范定義如下:(1) 組件編程模型。(2) 組件和主服務(wù)器的鏈接。(3) 服務(wù)器提供給組件的服務(wù)。(4) 各種各樣的人物角色。(5) 兼容性檢驗(yàn)裝置和編譯測(cè)試程序。在眾多的服務(wù)列表中,消息通信,事務(wù)處理,命名機(jī)制和其它應(yīng)用組件用到的服務(wù)是應(yīng)用服務(wù)器必須提供的。用j2ee進(jìn)行應(yīng)用開(kāi)發(fā)必須遵守經(jīng)典的3層結(jié)構(gòu)表現(xiàn)層,業(yè)務(wù)層和企業(yè)信息系統(tǒng)層。屬于各層的j2ee組件在開(kāi)發(fā)時(shí)遵守具體的j2ee標(biāo)準(zhǔn)。1、表現(xiàn)層或者網(wǎng)絡(luò)層這一層實(shí)際上又被分為客戶端和服務(wù)器端??蛻舳税g覽器,apple
9、ts,java應(yīng)用程序等和負(fù)責(zé)和服務(wù)器端的表現(xiàn)層或者業(yè)務(wù)層進(jìn)行交互。服務(wù)器端包括servlet、jsp和靜態(tài)網(wǎng)頁(yè)內(nèi)容。這些組件負(fù)責(zé)把業(yè)務(wù)數(shù)據(jù)傳遞給終端用戶。數(shù)據(jù)本身通常從業(yè)務(wù)層獲得有時(shí)也從企業(yè)信息系統(tǒng)層直接獲得。表現(xiàn)層的服務(wù)器端通常通過(guò)http協(xié)議來(lái)進(jìn)行訪問(wèn)。2、 業(yè)務(wù)層或者ejb層這一層包含ejb,即企業(yè)應(yīng)用的事務(wù)邏輯模型。這些組件提供了持久化機(jī)制和事務(wù)支持。ejb中的組件通過(guò)rmi被調(diào)用。在java虛擬機(jī)調(diào)用或者異步的消息傳遞,取決與ejb組件的類型。ejb規(guī)范定義了很多種組件。它們?cè)谡{(diào)用風(fēng)格(同步和異步,本地和遠(yuǎn)程)與狀態(tài)(完全狀態(tài),不可持久狀態(tài),可持久)方面不同。同步調(diào)用的ejb組件通
10、過(guò)特定的工廠代理對(duì)象來(lái)表現(xiàn)自己。這種工廠代理對(duì)象通常被ejb部署者綁定在jndi中。ejb對(duì)象允許或者本地ejb對(duì)象是特定ejb實(shí)例的代理。3、企業(yè)信息系統(tǒng)或者數(shù)據(jù)層這一層指的就是企業(yè)信息系統(tǒng),比如關(guān)系數(shù)據(jù)庫(kù),erp系統(tǒng),消息系統(tǒng)等。業(yè)務(wù)層和持久層在資源適配器的幫助下與該層進(jìn)行通信。資源適配器在java連結(jié)結(jié)構(gòu)中被定義。j2ee編程模型一直被認(rèn)為是分布式的編程模型,在該模型中應(yīng)用組件在j2ee服務(wù)器上運(yùn)行并且彼此可以相互交互。經(jīng)過(guò)初始化說(shuō)明和第一個(gè)服務(wù)實(shí)現(xiàn)后,該技術(shù),更顯著的說(shuō)ejb技術(shù),已經(jīng)明顯地從純粹的分布式計(jì)算模型轉(zhuǎn)向了本地交互。轉(zhuǎn)變的背后有合理的性能有關(guān)的原因,然而分布式的特征現(xiàn)在還存
11、在。j2ee規(guī)范已經(jīng)經(jīng)過(guò)了好幾次修訂,現(xiàn)在最穩(wěn)定的版本是1.3,1.4版本正處于重審階段。我們應(yīng)該把注意力放在1.3版本上,而實(shí)際上是在學(xué)習(xí)后者。適用與商業(yè)的j2ee實(shí)現(xiàn)可以大量的從bea系統(tǒng),ibm,oracle等贊助商得到。包括jboss和jonas在內(nèi)的開(kāi)源實(shí)現(xiàn)據(jù)稱兼容性也不錯(cuò)。最近名單上有多出了新的apache project geronimo。2.2 j2ee組件編程模型在我們基本的j2ee組件前,先讓我們強(qiáng)調(diào)一下什么是組件。軟件組件是有一系列的具體的接口和明確的上下文環(huán)境構(gòu)成。它可以被獨(dú)立的部署而且易于被第三方重構(gòu)。根據(jù)以上的定義,如下的組成j2ee應(yīng)用程序的實(shí)體可以看作是軟件組件
12、:(1) ejbs(會(huì)話,實(shí)體,消息驅(qū)動(dòng))。(2) web組件(servlet、jsp)。.(3) 消息目的。(4) 數(shù)據(jù)源。ejb和web組件被部署在由應(yīng)用服務(wù)贊助商提供的容器中.它們有定義良好的容器規(guī)則來(lái)管理生命周期,線程,持久化和其他問(wèn)題。ejb和web組件都利用jndi目錄機(jī)制去尋找資源和它們想要交互的其ejb組件。目錄被執(zhí)行的jndi環(huán)境被獨(dú)立的由容器的每個(gè)組件加以維護(hù)。該種環(huán)境下的綁定機(jī)制通常由組件部署的解釋者加以配置。消息目的地,像對(duì)話和隊(duì)列,是由消息服務(wù)執(zhí)行所提供的資源。數(shù)據(jù)源是提供給應(yīng)用服務(wù)器的為事務(wù)組件進(jìn)入到企業(yè)信息服務(wù)層提供數(shù)據(jù)接口,通常由被應(yīng)用服務(wù)器管理的jdbc連接池
13、實(shí)例化。一個(gè)j2ee編程者明確編寫(xiě)的項(xiàng)目只有ejb和web組件。這些用戶編寫(xiě)的組件彼此交互而且系統(tǒng)服務(wù)可以是明顯的也可以是隱含的。例如,ejb開(kāi)發(fā)者可以選擇明確的事務(wù)區(qū)分方式,這種方式意味著開(kāi)發(fā)者假設(shè)通過(guò)定義良好接口的事務(wù)經(jīng)理服務(wù)平臺(tái)來(lái)書(shū)寫(xiě)明確的程序交互?;蛘?,開(kāi)發(fā)者也可選擇容器管理事務(wù)區(qū)分的方式。這樣由于組件的事務(wù)行為通過(guò)他的描述者來(lái)定義而且全部用ejb容器來(lái)處理,因此作為一個(gè)隱式獨(dú)立的ejb提供潛在的事務(wù)管理服務(wù)。2.3 組件間的鏈接2.3.1 遠(yuǎn)程交互j2ee僅定義了三種可以在不同應(yīng)用服務(wù)器間傳遞的基本組件間連接類型。在這三種情況下,通信通過(guò)特定的java對(duì)象來(lái)完成。(1) 遠(yuǎn)程ejb調(diào)
14、用:同步的ejb調(diào)用通過(guò)主ejb對(duì)象和ejb對(duì)象接口來(lái)實(shí)現(xiàn)。(2) java連結(jié)器的外部連接:同步消息接收,同步和異步消息發(fā)送,用連接工廠和連接接口進(jìn)行數(shù)據(jù)庫(kù)查詢。(3) java連接器的內(nèi)部連接:異步消息傳遞進(jìn)入消息驅(qū)動(dòng)bean只能使用activation spec 對(duì)象。在前兩個(gè)實(shí)例中,應(yīng)用組件的開(kāi)發(fā)者不僅書(shū)寫(xiě)執(zhí)行在組件的運(yùn)行時(shí)jndi環(huán)境中的對(duì)象目錄代碼,而且書(shū)寫(xiě)發(fā)布方法調(diào)用,與遠(yuǎn)程的組件相互發(fā)送和接受消息。組件的運(yùn)行時(shí)jndi環(huán)境為每一個(gè)組件部署所創(chuàng)建。環(huán)境中的綁定在組件部署時(shí)由部署者進(jìn)行初始化。這些綁定被假設(shè)為是靜態(tài)的,因?yàn)橐?guī)格中沒(méi)有提供任何的容器和組件間協(xié)議去提示綁定發(fā)生了變化。在
15、 java連接器的內(nèi)部通信情景下,activation spec 對(duì)象查詢以及所有的相應(yīng)的m容器隱式的完成。雖然查詢的協(xié)議還沒(méi)有被標(biāo)準(zhǔn)化,但是假設(shè)一個(gè)基于jmx或者jndi的查詢是合理的。 假設(shè)潛在的應(yīng)用服務(wù)器提供了所有的設(shè)備去控制部署過(guò)程的每一步,那么在兩個(gè)j2ee組件間確立一個(gè)連接需要涉及:(1) 部署目標(biāo)組件類。(2) 創(chuàng)建一個(gè)特定的java對(duì)象用作目標(biāo)組件代理。(3) 用組件的命名服務(wù)去綁定目標(biāo)。(4) 啟動(dòng)目標(biāo)組件。(5) 部署指定的組件類。(6) 在主機(jī)的命名服務(wù)中,創(chuàng)建和進(jìn)行指定組件的運(yùn)行環(huán)境。(7) 啟動(dòng)指定的組件。然而,沒(méi)有一個(gè)現(xiàn)代的應(yīng)用服務(wù)器允許詳細(xì)的控制所有組件類型的部署
16、過(guò)程除了在它們的部署解釋器中的有限的選擇。因此我們的架構(gòu)將使用簡(jiǎn)化的途徑,它所依賴的特征在現(xiàn)在的大多數(shù)的應(yīng)用服務(wù)器上都可以得到。(1) 動(dòng)態(tài)部署消息目的和數(shù)據(jù)源的能力。(2) 創(chuàng)建和綁定特定的jndi目標(biāo)去訪問(wèn)消息目的和數(shù)據(jù)源的能力。(3) 把初始綁定的ejb對(duì)象到ejb部署組件的能力。(4) 用在參考組件運(yùn)行環(huán)境中的jndi指引去指出綁定的參考ejb的能力。在只有相同的應(yīng)用服務(wù)器的架構(gòu)中,上面的功能對(duì)通過(guò)簡(jiǎn)單的部署控制解釋器方式來(lái)控件間的連接已經(jīng)足夠了。然而,在不同應(yīng)用服務(wù)器的環(huán)境下,由于跨服務(wù)器的類下載問(wèn)題,這種簡(jiǎn)單的控制解釋器的方式是不夠的。2.3.2 本地交互一些組件間的交互可以發(fā)生在
17、同一地點(diǎn)的相同應(yīng)用服務(wù)器虛擬機(jī)的組件間,有時(shí)候甚至可以發(fā)生在只有相同容器的組件間。在web層,這種交互的例子是 servlet到 servlet的請(qǐng)求轉(zhuǎn)發(fā)。在ejb層,這種交互的例子是cmp實(shí)體關(guān)系和通過(guò)ejb本地接口的調(diào)用。這種本地部署所關(guān)心的不是在分布式架構(gòu)中去表現(xiàn)而是去增強(qiáng)一致性。因此,這種架構(gòu)把所有的本地的組件請(qǐng)求當(dāng)作一個(gè)單一的組件加以對(duì)待。2.4 部署j2ee應(yīng)用程序和系統(tǒng)服務(wù)2.4.1 部署應(yīng)用程序組件部署和拆卸標(biāo)準(zhǔn)的j2ee組件還沒(méi)有統(tǒng)一的標(biāo)準(zhǔn),因此每個(gè)應(yīng)用服務(wù)的提供商對(duì)組件的部署和拆卸提供了單獨(dú)的功能于j2ee規(guī)范中沒(méi)有定義標(biāo)準(zhǔn)組件的包,包的格式和包內(nèi)的基于xml部署解釋器的位
18、置,因此這種包對(duì)于沒(méi)有所屬權(quán)變化的應(yīng)用服務(wù)器不需要部署。具體變化的例子有:(1) 支持或者取代標(biāo)準(zhǔn)所有者解釋器的新的所有者解釋器的產(chǎn)生。(2) 具體服務(wù)應(yīng)用程序類的代碼的更替。為了著手構(gòu)建一個(gè)能夠部署不可網(wǎng)絡(luò)的動(dòng)態(tài)的分布式的架構(gòu),我們提出了一種普遍的部署單元即一個(gè)簡(jiǎn)單的基于xml部署的解釋器或者是一組類似的綁定到文檔中的解釋器。文檔可能包含用于執(zhí)行組件的java類或者任何其它的所需組件。相應(yīng)地,部署解釋器也可以簡(jiǎn)單地用url來(lái)索引代碼。我們假設(shè)這種動(dòng)態(tài)的部署和拆卸服務(wù)存在于所有的兼容的j2ee服務(wù)器上而且在不理解類重載相關(guān)問(wèn)題時(shí)一個(gè)健壯的類重載結(jié)結(jié)構(gòu)的應(yīng)用服務(wù)器就能夠重復(fù)的部署生命周期。大多數(shù)
19、現(xiàn)代的應(yīng)用服務(wù)器都提供這樣的功能。2.4.2 部署系統(tǒng)組件對(duì)應(yīng)用組件來(lái)說(shuō),j2ee規(guī)范只是少了在部署和拆卸時(shí)的明確定義,而對(duì)系統(tǒng)服務(wù)來(lái)說(shuō),在這方面做的更糟。對(duì)系統(tǒng)服務(wù)來(lái)說(shuō)不僅沒(méi)有具體的定義一個(gè)標(biāo)準(zhǔn)化的部署,實(shí)際上,這個(gè)規(guī)格甚至連沒(méi)有強(qiáng)調(diào)在生命周期屬性方面的要求,更不用手強(qiáng)調(diào)依賴也潛在的系統(tǒng)服務(wù)的應(yīng)用組件的明確規(guī)范了取而代之的是它定義了部署者的角色,這個(gè)角色負(fù)責(zé)確保像組件的本性和系統(tǒng)的解釋器所暗示的那樣,所需的服務(wù)是基于應(yīng)用組件對(duì)系統(tǒng)服務(wù)依賴性的基礎(chǔ)之上。例如,假如有一個(gè)事務(wù)容器要至少用一種方法去開(kāi)始一個(gè)新的事務(wù),那么一個(gè)帶有這樣的事務(wù)容器的ejb就需要在應(yīng)用層表示事務(wù)管理服務(wù)。與之相似的是,一
20、個(gè)消息驅(qū)動(dòng)的bean,也隱式需要一種運(yùn)行在網(wǎng)絡(luò)上消息服務(wù)實(shí)例。它為mdb管理消息目的以及基于查詢的java連接器通過(guò)它的管理服務(wù)層去提供這種消息服務(wù)。考慮到應(yīng)用層可能通常只用到了應(yīng)用服務(wù)器所提供的服務(wù)的一個(gè)子集,根據(jù)應(yīng)用層的需要允許遞增的配置服務(wù)的組件應(yīng)用服務(wù)器允許更高效的利用多種資源。包括,開(kāi)源的應(yīng)用服務(wù)器,jboss和onas在內(nèi),已經(jīng)有多種j2ee應(yīng)用服務(wù)器已經(jīng)全部或者部分的實(shí)現(xiàn)了組件化。我們感覺(jué)到通過(guò)動(dòng)態(tài)的部署和拆卸系統(tǒng)服務(wù),動(dòng)態(tài)的配置應(yīng)用服務(wù)器對(duì)動(dòng)態(tài)分布的部署j2ee應(yīng)用程序是一種十分重要的構(gòu)建資源有效型框架的方法。因此我們提倡并將把用jboss應(yīng)用服務(wù)器設(shè)計(jì)的微內(nèi)核的應(yīng)用服務(wù)器用作
21、一個(gè)模型。在該模型中,一個(gè)微型的服務(wù)包括了系統(tǒng)調(diào)用總線,一個(gè)穩(wěn)健的類下載子系統(tǒng),一些命名子系統(tǒng)和一個(gè)動(dòng)態(tài)配置子系統(tǒng)。所有其它的服務(wù)是熱部署并且通過(guò)一個(gè)普通的調(diào)用總線來(lái)進(jìn)行通信。例如,jboss利用java管理擴(kuò)展服務(wù)器來(lái)實(shí)現(xiàn)基本的命名和調(diào)用功能。除此之外,jboss實(shí)現(xiàn)了一個(gè)先進(jìn)的類下載子系統(tǒng)和部署服務(wù)。所有其它的jboss是動(dòng)態(tài)配置的,并外在的表現(xiàn)為具有良好機(jī)制和生命周期的jmx mbeans.這樣的一種應(yīng)用服務(wù)器根據(jù)系統(tǒng)服務(wù)外在利用應(yīng)用組件去設(shè)計(jì)相關(guān)功能,并且只有需要的系統(tǒng)服務(wù)才會(huì)得到合理配置和部署! 參考文獻(xiàn)1 matt bishop. computer security: art an
22、d science. new york, 20022 matt bishop. vulnerabilities analysis. proceedings of the second international symposium on recent advances in intrusion detection. los angeles 20063 balasubra maniyan. architecture for intrusion detection using autonomous agentsm. department of computer sciences, purdue u
23、niversity, 1998.infrastructure for automatic dynamic deploymentof j2ee application in distributed environmentsanatoly akkerman, alexander totok, and vijay karamchetiabstract: in order to achieve such dynamic adaptation, we need an infrastructure for automating j2ee application deployment in such an
24、environment. this need is quite evident to anyone who has ever tried deploying a j2ee application even on a single application server, which is a task that involves a great deal of configuration of both the system services and application components.key words: j2ee; component; distributed; dynamic d
25、eployment; 1 introductionin recent years, we have seen a significant growth in component-based enterprise application development. these applications are typically deployed on company intranets or on the internet and are characterized by high transaction volume, large numbers of users and wide area
26、access. traditionally they are deployed in a central location, using server clustering with load balancing (horizontal partitioning) to sustain user load. however, horizontal partitioning has been shown very efficient only in reducing application-related overheads of user-perceived response times, w
27、ithout having much effect on network-induced latencies. vertical partitioning (e.g., running web tier and business tier in separate vms) has been used for fault isolation and load balancing but it is sometimes impractical due to significant run-time overheads (even if one would keep the tiers on a f
28、ast local-area network) related to heavy use of remote invocations. recent work 14 in the context of j2ee component based applications has shown viability of vertical partitioning in wide-area networks without incurring the aforementioned overheads. the key conclusions from that study can be summari
29、zed as follows: using properly designed applications, vertical distribution across wide-area networks improves user-perceived latencies. wide-area vertical layering requires replication of application components and maintaining consistency between replicas. additional replicas may be deployed dynami
30、cally to handle new requests. different replicas may, in fact, be different implementations of the same component based on usage (read-only, read-write). new request paths may reuse components from previously deployed paths.applying intelligent monitoring 6 and ai planning 2, 12 techniques in conjun
31、ction with the conclusions of that study, we see a potential for dynamic adaptation in industry-standard j2ee component-based applications in wide area networksthrough deployment of additional application components dynamically based on active monitoring. however, in order to achieve such dynamic ad
32、aptation, we need an infrastructure for automating j2ee application deployment in such an environment. this need is quite evident to anyone who has ever tried deploying a j2ee application even on a single application server, which is a task that involves a great deal of configuration of both the sys
33、tem services and application components. for example one has to set up jdbc data sources, messaging destinations and other resource adapters before application components can be configured and deployed. in a wide area deployment that spans multiple server nodes, this proves even more complex, since
34、more system services that facilitate inter-node communications need to be configured and started and a variety of configuration data, like ip addresses, port numbers, jndi names and others have to be consistently maintained in various configuration files on multiple nodes.this distributed deployment
35、 infrastructure must be able to: address inter-component connectivity specification and define its effects on component configuration and deployment, address application component dependencies on application server services, their configuration and deployment, provide simple but expressive abstracti
36、ons to control adaptation through dynamic deployment and undeployment of components, enable reuse of services and components to maintain efficient use of network nodes resources, provide these facilities without incurring significant additional design effort on behalf of application programmers.in t
37、his paper we propose the infrastructure for automatic dynamic deployment of j2ee applications, which addresses all of the aforementioned issues. the infrastructure defines architecture description languages (adl) for component and link description and assembly. the component description language is
38、used to describe application components and links. it provides clear separation of application components from system components. a flexible type system is used to define compatibility of component ports and links. a declaration and expression language for configurable component properties allows fo
39、r specification of inter-component dependencies and propagation of properties between components. the component (replica) assembly language allows for assembly of replicas of previously defined components into application paths byconnecting appropriate ports via link replicas and specifying the mapp
40、ing of these component replicas onto target application server nodes. the component configuration process evaluates an application paths correctness, identifies the dependenciesof application components on system components, and configures component replicas for deployment. an attempt is made to mat
41、ch and reuse any previously deployed replicas in the new path based on their configurations. we implement the infrastructure as a part of the jboss open source java application server 11 and test it on severalsample j2ee applications java pets tore 23, rubies 20 and tpc-w-nyu 32. the infrastructure
42、implementation utilizes the jbosss extendable micro-kernel architecture, based on the jmx 27 specification. componentized architecture of jboss allows incremental service deployments depending on the needs of deployed applications. we believe that dynamic reconfiguration of application servers throu
43、gh dynamic deployment and undeployment of system services is essential to building a resource-efficient framework for dynamic distributed deployment of j2ee applications. the rest of the paper is organized as follows. section 2 provides necessary background for understanding the specifics of the j2e
44、e component technology which are relevant to this study. section 3 gives a general description of the infrastructure architecture, while section 4 goes deeper in describing particularly important and interesting internal mechanisms of the infrastructure. section 5 describes the implementation of the
45、 framework, and related work is discussed in section 6.2 j2ee background2.1 introductioncomponent frameworks. a component framework is a middleware system that supports applications consisting of components conforming to certain standards. application components are “plugged” into the component fram
46、ework, which establishes their environmental conditions and regulates the interactions between them. this is usually done through containers, component holders, which also provide commonly required support for naming, security, transactions, and persistence. component frameworks provide an integrate
47、d environment for component execution, as a result significantly reduce the effort .it takes to design, implement, deploy, and maintain applications. current day industry component framework standards are represented by object management groups corba component model 18, sun microsystems java 2 platf
48、orm enterprise edition (j2ee) 25 and microsofts .net 17, with j2ee being currently the most popular and widely used component framework in the enterprise arena.j2ee. java 2 platform enterprise edition (j2ee) 25 is a comprehensive standard for developing multi-tier enterprise java applications. the j
49、2ee specification among other things defines the following: component programming model, component contracts with the hosting server, services that the platform provides to these components, various human roles, compatibility test suites and compliance testing procedures.among the list of services t
50、hat a compliant application server must provide are messaging, transactions, naming and others that can be used by the application components. application developed using j2ee adhere to the classical 3-tier architectures presentation tier, business tier, and enterprise information system (eis) tier
51、(see fig. 1). j2ee components belonging to each tier are developed adhering to thespecific j2ee standards.1. presentation or web tier.this tier is actually subdivided into client and server sides. the client side hosts a web browser, applets and java applications that communicate with the server sid
52、e of presentation tier or the business tier. the server side hosts java servlet components 30, java server pages (jsps) 29 and static web content. these components are responsible for presenting business data to the end users. the data itself is typically acquired from the business tier and sometime
53、s directly from the enterprise information system tier. the server side of the presentation tier is typically accessed through http(s) protocol.2. business or ejb tier.this tier consists of enterprise java beans (ejbs) 24 that model the business logic of the enterprise application. these components
54、provide persistence mechanisms and transactional support. the components in the ejb tier are invoked through remote invocations (rmi), in-jvm invocations or asynchronous message delivery, depending on the type of ejb component. the ejb specification defines several types of components. they differ i
55、n invocation style (synchronous vs. asynchronous, local vs. remote) and statefulness: completely stateless (e.g., message-driven bean), stateful non-persistent(e.g., stateful session bean), stateful persistent (e.g., entity bean). synchronously invocable ejb components expose themselves through a sp
56、ecial factory proxy object (an ejb home object, which is specific to a given ejb), which is typically bound in jndi by the deployer of the ejb. the ejb home object allows creation or location of an ejbobject, which is a proxy to a particular instance of an ejb 1.3. enterprise information system (eis
57、) or data tier.this tier refers to the enterprise information systems, like relational databases, erp systems, messaging systems and the like. business and presentation tier component communicate with this tier with the help of resource adapters as defined by the java connector architecture 26.the j
58、2ee programming model has been conceived as a distributed programming model where application components would run in j2ee servers and communicate with each other. after the initial introduction and first server implementations, the technology, most notably, the ejb technology has seen some a significant shift away from purely distributed computing model towards local interactions 2. there were very legitimate performance-related reasons behind this shift, however thedistributed features are still available. the j2ee specification has seen several revisions, the latest stable
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五年度財(cái)務(wù)信息系統(tǒng)集成合同3篇
- 2024石子深加工技術(shù)研發(fā)與應(yīng)用合同3篇
- 2024玩具樂(lè)園設(shè)備采購(gòu)及租賃服務(wù)合同3篇
- 2024版影視作品版權(quán)轉(zhuǎn)讓與授權(quán)播放合同
- 2025年松樹(shù)造林項(xiàng)目采購(gòu)合同3篇
- 二零二五版船舶光租及船舶安全管理體系合同3篇
- 二零二五年度安置房項(xiàng)目公共設(shè)施維護(hù)合同3篇
- 2025年度淋浴房綠色環(huán)保材料采購(gòu)與安裝服務(wù)合同4篇
- 2025年度鋁材貿(mào)易結(jié)算與風(fēng)險(xiǎn)管理合同4篇
- 二零二五年度跨境電商進(jìn)口采購(gòu)合同3篇
- 領(lǐng)導(dǎo)溝通的藝術(shù)
- 發(fā)生用藥錯(cuò)誤應(yīng)急預(yù)案
- 南潯至臨安公路(南潯至練市段)公路工程環(huán)境影響報(bào)告
- 綠色貸款培訓(xùn)課件
- 大學(xué)生預(yù)征對(duì)象登記表(樣表)
- 主管部門(mén)審核意見(jiàn)三篇
- 初中數(shù)學(xué)校本教材(完整版)
- 父母教育方式對(duì)幼兒社會(huì)性發(fā)展影響的研究
- 新課標(biāo)人教版數(shù)學(xué)三年級(jí)上冊(cè)第八單元《分?jǐn)?shù)的初步認(rèn)識(shí)》教材解讀
- (人教版2019)數(shù)學(xué)必修第一冊(cè) 第三章 函數(shù)的概念與性質(zhì) 復(fù)習(xí)課件
- 重慶市銅梁區(qū)2024屆數(shù)學(xué)八上期末檢測(cè)試題含解析
評(píng)論
0/150
提交評(píng)論