已閱讀5頁(yè),還剩26頁(yè)未讀, 繼續(xù)免費(fèi)閱讀
版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
經(jīng)典JavaEE課程,段鵬松,第9章消息驅(qū)動(dòng)EJB,了解MDB的原理掌握MDB的開(kāi)發(fā)技能了解MDB的生命周期會(huì)使用NetBeans開(kāi)發(fā)EJB,課程目標(biāo),目錄,JMS和EJB使用消息驅(qū)動(dòng)Bean使用NetBeans開(kāi)發(fā)EJBEJB學(xué)習(xí)小結(jié),JMS概述,JMS:JavaMessageService。JMS是JavaEE規(guī)范中的一個(gè)重要組成部分,它是一種企業(yè)消息處理的規(guī)范。JMS的作用就像一個(gè)智能交換機(jī),它負(fù)責(zé)路由分布式應(yīng)用中各組件所發(fā)出的消息。JMS提供了一組通用的Java應(yīng)用程序API,開(kāi)發(fā)者可以通過(guò)這些API來(lái)創(chuàng)建、發(fā)送、接收、讀取消息。JMS與具體廠商無(wú)關(guān)。,JMS概述,JMS架構(gòu)的組成部分JMS服務(wù)器:路由消息的服務(wù)系統(tǒng)JMS生產(chǎn)者:負(fù)責(zé)創(chuàng)建并發(fā)送消息的程序組件JMS消費(fèi)者:負(fù)責(zé)讀取并處理消息的程序組件實(shí)際應(yīng)用中消息消費(fèi)者通常都是異步消費(fèi)者,而消息驅(qū)動(dòng)Bean就是一個(gè)標(biāo)準(zhǔn)的JMS消息異步消費(fèi)者。,JMS概述,JMS的編程過(guò)程很簡(jiǎn)單,概括為:應(yīng)用程序A發(fā)送一條消息到消息服務(wù)器的某個(gè)目的地(Destination),然后消息服務(wù)器把消息轉(zhuǎn)發(fā)給應(yīng)用程序B。因?yàn)閼?yīng)用程序A和應(yīng)用程序B沒(méi)有直接的代碼關(guān)連,所以?xún)烧邔?shí)現(xiàn)了解偶。如下圖:,JMS概述,JMS支持兩種消息傳遞模型:點(diǎn)對(duì)點(diǎn)(point-to-point,簡(jiǎn)稱(chēng)PTP)和發(fā)布/訂閱(publish/subscribe,簡(jiǎn)稱(chēng)pub/sub)。這兩種消息傳遞模型非常相似,但有以下區(qū)別:PTP消息傳遞模型規(guī)定了一條消息只能傳遞給一個(gè)接收方。采用javax.jms.Queue表示。Pub/sub消息傳遞模型允許一條消息傳遞給多個(gè)接收方。采用javax.jms.Topic表示。,JMS概述,PTP消息傳遞模型,發(fā)布/訂閱消息傳遞模型,JMS概述,JMS定義了五種不同的消息正文格式StreamMessage-Java原始值的數(shù)據(jù)流MapMessage-一套名稱(chēng)-值對(duì)TextMessage-一個(gè)字符串對(duì)象ObjectMessage-一個(gè)序列化的Java對(duì)象BytesMessage-一個(gè)未解釋字節(jié)的數(shù)據(jù)流,為什么使用MDB,MDB是EJB和JMS結(jié)合的產(chǎn)物。MDB也存在于EJB容器中,而且也可以利用EJB提供的系統(tǒng)服務(wù),如事務(wù)、安全和并發(fā)控制等,但MDB并不直接與客戶(hù)端交互。MDB的作用是為了簡(jiǎn)化開(kāi)發(fā)。當(dāng)開(kāi)發(fā)者需要通過(guò)JMS消息機(jī)制進(jìn)行通信時(shí),JMS消息生產(chǎn)者按原來(lái)的方式發(fā)送消息,而MDB規(guī)范則簡(jiǎn)化了JMS異步消費(fèi)者的開(kāi)發(fā)。,使用MDB的設(shè)計(jì)原則,無(wú)狀態(tài)SessionBean和MDB的區(qū)別無(wú)狀態(tài)SessionBean定義了業(yè)務(wù)方法,允許客戶(hù)端直接調(diào)用;MDB不允許客戶(hù)端直接調(diào)用,它只是一個(gè)消息監(jiān)聽(tīng)者。MDB的適用場(chǎng)景該業(yè)務(wù)方法的處理時(shí)間較長(zhǎng),而且處理時(shí)間可能具有一定的不確定性;客戶(hù)端調(diào)用該方法處理后無(wú)須立即得到返回結(jié)果。,MDB的通信機(jī)制,MDB的通信機(jī)制通過(guò)onMessage()方法的形參來(lái)獲取JMS消息對(duì)象,并提取其中的信息;調(diào)用業(yè)務(wù)邏輯組件(通常就是無(wú)狀態(tài)SessionBean)來(lái)對(duì)該消息中的消息進(jìn)行處理。,目錄,JMS和EJB使用消息驅(qū)動(dòng)Bean使用NetBeans開(kāi)發(fā)EJBEJB學(xué)習(xí)小結(jié),消息驅(qū)動(dòng)EJB的Bean類(lèi)的基本要求,MDB的Bean實(shí)現(xiàn)類(lèi)必須直接或間接實(shí)現(xiàn)消息監(jiān)聽(tīng)器接口;MDB類(lèi)只能是一個(gè)使用public修飾的POJO,它不能是其他MDB的子類(lèi);MDB類(lèi)必須包含無(wú)參的構(gòu)造器;不要使用final或abstract修飾MDB的Bean類(lèi);MDB類(lèi)中不應(yīng)該定義finalize()方法,如何定義MDB,MessageDriven指定MDBBean實(shí)現(xiàn)的實(shí)現(xiàn)接口其常用屬性有mappedName(對(duì)JBoss無(wú)效)namemessageListeneractivationConfig,如何定義MDB,ActivationConfigProperty為MDB配置系列額外的屬性其常用屬性有acknowledgeModedestinationTypedestination(對(duì)JBoss起作用)實(shí)際操作演示先在應(yīng)用服務(wù)器中配置好JMS服務(wù)器相關(guān)內(nèi)容再把MDB的jar文件部署到應(yīng)用服務(wù)器中,運(yùn)行結(jié)果(Weblogic),運(yùn)行結(jié)果(JBoss),實(shí)現(xiàn)MessageListener,實(shí)際項(xiàng)目中,開(kāi)發(fā)者可能更希望讓MDB的Bean實(shí)現(xiàn)類(lèi)實(shí)現(xiàn)MessageListener接口,這樣可以讓編譯器執(zhí)行更嚴(yán)格的檢查。實(shí)現(xiàn)了MessageListener接口后,就要實(shí)現(xiàn)該接口中的onMessage(Messagemsg)方法實(shí)際操作演示,MDB的生命周期,和無(wú)狀態(tài)SessionBean的類(lèi)似,MDB的生命周期也有三個(gè)狀態(tài):不存在狀態(tài)待命狀態(tài)被銷(xiāo)毀狀態(tài)PostConstructPreDestroy實(shí)際操作演示,運(yùn)行結(jié)果,MDB中的依賴(lài)注入,EJB:EJB依賴(lài)注入Resource:資源依賴(lài)注入實(shí)際操作演示通過(guò)資源注入,獲取數(shù)據(jù)源通過(guò)EJB注入,調(diào)用其業(yè)務(wù)邏輯分別處理TextMessage和MapMessage,并且存儲(chǔ)到數(shù)據(jù)庫(kù)中,運(yùn)行結(jié)果,事務(wù)管理和異常處理,事務(wù)管理的分類(lèi)CMTBMT事務(wù)管理所使用的annotationTransactionManagementTransactionAttribute異常處理系統(tǒng)異常自定義異常,目錄,JMS和EJB使用消息驅(qū)動(dòng)Bean使用NetBeans開(kāi)發(fā)EJBEJB學(xué)習(xí)小結(jié),使用NetBeans開(kāi)發(fā)SessionBean,NetBeans里面提供了圖形化的操作界面,方便開(kāi)發(fā)者快速開(kāi)發(fā)SessionBean。實(shí)際操作演示,使用NetBeans開(kāi)發(fā)MDB,NetBeans里面提供了圖形化的操作界面,方便開(kāi)發(fā)者快速開(kāi)發(fā)MDB。實(shí)際操作演示,目錄,JMS和EJB使用消息驅(qū)動(dòng)Bean使用NetBeans開(kāi)發(fā)EJBEJB學(xué)習(xí)小結(jié),EJB學(xué)習(xí)小結(jié),EJB3中的Bean分類(lèi)SessionBean無(wú)狀態(tài)SessionBean允許本地調(diào)用-local允許遠(yuǎn)程調(diào)用-remote有狀態(tài)SessionBean允許本地調(diào)用-local允許遠(yuǎn)程調(diào)用-remoteMDB是一種特殊的無(wú)狀態(tài)SessionBean不允許客戶(hù)端直接調(diào)用可以調(diào)用其他SessionBean,EJB學(xué)習(xí)小結(jié),EJB的
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 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ì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年高職電子技術(shù)(電子電路設(shè)計(jì))試題及答案
- 2025年大學(xué)舞蹈表演(舞蹈表演技能)試題及答案
- 2025年中職汽車(chē)運(yùn)用與維修(汽車(chē)美容)試題及答案
- 2025年中職(客戶(hù)服務(wù)實(shí)務(wù))客戶(hù)服務(wù)綜合測(cè)試試題及答案
- 2025年高職(旅游管理)導(dǎo)游服務(wù)技能階段測(cè)試題及答案
- 2025年大學(xué)建筑電氣與智能化(電氣工程理論)試題及答案
- 2025年中職(物聯(lián)網(wǎng)技術(shù)應(yīng)用)物聯(lián)網(wǎng)通信技術(shù)試題及答案
- 2025年高職新能源汽車(chē)運(yùn)營(yíng)應(yīng)用管理(管理技術(shù))試題及答案
- 2026年物業(yè)客服(客戶(hù)關(guān)系維護(hù))試題及答案
- 2025年中職農(nóng)資營(yíng)銷(xiāo)與服務(wù)(產(chǎn)品推廣)模擬試題
- 車(chē)間電纜整改方案模板(3篇)
- 徐州村務(wù)管理辦法
- 廣東省惠州市2026屆高三上學(xué)期第一次調(diào)研考試 歷史 含答案
- 政協(xié)機(jī)車(chē)輛管理辦法
- 食品加工助劑管理辦法
- DB50∕T 1604-2024 地質(zhì)災(zāi)害防治邊坡工程結(jié)構(gòu)可靠性設(shè)計(jì)規(guī)范
- 非現(xiàn)場(chǎng)執(zhí)法培訓(xùn)課件
- 中國(guó)電氣裝備資產(chǎn)管理有限公司招聘筆試題庫(kù)2025
- 糖尿病足的護(hù)理常規(guī)講課件
- 2025年高考英語(yǔ)復(fù)習(xí)難題速遞之語(yǔ)法填空(2025年4月)
- 2025外籍工作人員勞動(dòng)合同范本
評(píng)論
0/150
提交評(píng)論