JMS面向Web的應(yīng)用與面向桌面的應(yīng)用相比,有特殊的用戶環(huán)境要求:同一個(gè)消息必須能被若干未知的用戶消費(fèi),因此在消息接收方必須有"接收而不確認(rèn)"的提交機(jī)制;本文以CWNF校務(wù)系統(tǒng)為實(shí)現(xiàn)案例,討論面向Web的JMS應(yīng)用系統(tǒng)消息提交原理及采用的關(guān)鍵技術(shù)。
消息傳遞是一種在軟件組件或應(yīng)用之間進(jìn)行分布式通信的松散耦合方法,與各種緊密耦合通信技術(shù)(如CORBA、Java RMI、COM/DCOM)相比,不同之處在于:①消息系統(tǒng)是一種對(duì)等實(shí)施,通信雙方即消息的發(fā)送者和接受者都是該系統(tǒng)中的客戶端,彼此不呈C/S關(guān)系;②通信雙方的工作是異步的;③基于消息格式一致,通信雙方只需一個(gè)中介來存儲(chǔ)并管理消息就可以實(shí)現(xiàn)通信,而緊密耦合技術(shù)則需要知道遠(yuǎn)程方法在本地的接口。因自身特點(diǎn),消息傳遞技術(shù)在企業(yè)中和企業(yè)間有較廣泛的應(yīng)用需求。
JMS(Java Message Service)是J2EE企業(yè)平臺(tái)的Java消息服務(wù),目前主流J2EE產(chǎn)品的JMS都實(shí)現(xiàn)了存儲(chǔ)功能,JMS客戶端通過JMS API創(chuàng)建,彼此間通過目的地(Destination)對(duì)象進(jìn)行通信;可是JMS消息系統(tǒng)多見于桌面應(yīng)用,而Web應(yīng)用鮮見,本文以筆者開發(fā)的CWNF校務(wù)系統(tǒng)為案例,討論面向Web的JMS應(yīng)用系統(tǒng)的實(shí)現(xiàn)原理及采用的關(guān)鍵技術(shù)。
JMS應(yīng)用系統(tǒng)有4個(gè)部分:①JMS提供者(JMS Provider),是一個(gè)邏輯數(shù)據(jù)存儲(chǔ)體,并提供管理工具和控制特性;②JMS客戶端,是用Java語言編寫的發(fā)送或接收消息的組件或應(yīng)用;③消息,是JMS客戶端間被傳遞的承載信息的對(duì)象;④被管理對(duì)象,是系統(tǒng)管理員為客戶端預(yù)置的JMS對(duì)象,包括目的地對(duì)象和連接工廠對(duì)象,其中目的地對(duì)象是客戶端間的消息中介。這4個(gè)部分通過JNDI相關(guān)聯(lián):管理員通過管理工具把目的地對(duì)象和連接工廠對(duì)象綁定到一個(gè)JNDI API命名空間中,JMS客戶端就可以在命名空間中查找這些對(duì)象,并通過JMS提供者建立與這些對(duì)象的邏輯連接,從而彼此之間實(shí)現(xiàn)通信(圖1)。JMS支持2種消息傳遞域:點(diǎn)到點(diǎn)、發(fā)布/訂閱,與之相對(duì)應(yīng)的消息目的地對(duì)象也有2種:隊(duì)列、主題。
通常,無論是消息發(fā)送方還是接收方,桌面應(yīng)用都不容許消息丟失或重復(fù),JMS消息提交機(jī)制是基于這個(gè)要求的,它們從不同方面保證該要求的實(shí)現(xiàn):①在接收方控制消息的確認(rèn)。通過確認(rèn)保證一個(gè)接收者對(duì)一個(gè)消息只消費(fèi)一次,在非事務(wù)性的會(huì)話中,消息確認(rèn)方式取決于create×××Session方法第二個(gè)參數(shù)的值;在事務(wù)性會(huì)話中,無論由Bean管理事務(wù)還是由Bean容器管理事務(wù),消息確認(rèn)都由Bean容器自動(dòng)完成。②在發(fā)送方指定消息的提交模式和生存期。提交模式有兩種:PERSISTENT(穩(wěn)定存儲(chǔ))和NON_PERSISTENT(非穩(wěn)定存儲(chǔ)),穩(wěn)定存儲(chǔ)保證在故障情況下消息不會(huì)丟失;生存期決定一個(gè)消息在存儲(chǔ)中介中的存在壽命,JMS提供者會(huì)自動(dòng)摧毀到期的消息。③創(chuàng)建持久定閱的接收方。在發(fā)布/訂閱系統(tǒng)中,持久訂閱者可以接收到在訂閱者關(guān)閉階段消息發(fā)送方發(fā)布的消息。
但是Web應(yīng)用系統(tǒng)在消息接收方有Web特有的用戶環(huán)境要求:①若干個(gè)用戶共用一個(gè)JMS客戶端組件,因此消息就應(yīng)向一個(gè)消息接收者提交而不需確認(rèn),具有容器自動(dòng)確認(rèn)功能的Bean是無法實(shí)現(xiàn)這一要求的;在一個(gè)組件內(nèi)如果把會(huì)話設(shè)置成事務(wù)性的,而這個(gè)組件的容器又不具有事務(wù)管理能力,則這個(gè)組件就能做到"接收而不確認(rèn)",在Web應(yīng)用系統(tǒng)中只有Servlet組件符合這一要求。②JMS客戶端的消息接收者經(jīng)常關(guān)閉,為了接收在關(guān)閉期間發(fā)送來的消息,消息接收者必定是基于主題的持久定閱者,所以面向Web的JMS應(yīng)用系統(tǒng)必定采用發(fā)布/訂閱消息傳遞域。
CWNF是一個(gè)面向Web的JMS校務(wù)系統(tǒng),用于校園發(fā)布通知及征求意見等校務(wù)工作,通知分為2類:普通通知和征求意見性通知。
該系統(tǒng)用戶分成3類,用戶不同,處理模型也不同,基本情況如下:①發(fā)布用戶,擁有通知發(fā)布權(quán),向主題發(fā)布通知;②署名用戶,查閱通知,也可發(fā)表對(duì)征求意見性通知的反饋意見;③匿名用戶,只查閱通知。
系統(tǒng)中的數(shù)據(jù)因此有2類:通知、反饋。接收方接收的數(shù)據(jù)將形成一個(gè)XML文檔對(duì)象,以便發(fā)往Web瀏覽器顯示;基于這樣的要求,考察下面2個(gè)問題:①系統(tǒng)中各方之間的數(shù)據(jù)關(guān)系,②各方數(shù)據(jù)的形式。
主要的數(shù)據(jù)關(guān)系有3個(gè):①通知發(fā)送方與通知接收方的數(shù)據(jù)關(guān)系,②反饋發(fā)送方與反饋接收方的數(shù)據(jù)關(guān)系,③通知接收方與反饋接收方的數(shù)據(jù)關(guān)系。(如圖2)在發(fā)送方,數(shù)據(jù)(通知或反饋)是一件一件的發(fā)送,在接收方,數(shù)據(jù)(通知或反饋)則是批接收,是對(duì)應(yīng)發(fā)送方數(shù)據(jù)的集合,因此在發(fā)送方?jīng)]有必要把數(shù)據(jù)直接加工成XML文檔對(duì)象形式,只要生成能構(gòu)成XML文檔對(duì)象的元素對(duì)象即可;而通知接收方與反饋接收方的數(shù)據(jù)關(guān)系則是:每一條征求意見性通知都有相關(guān)的一個(gè)反饋集合。
系統(tǒng)的數(shù)據(jù)流模型如下:
①通知發(fā)送方:表單數(shù)據(jù)→XML元素(通知)→主題(存儲(chǔ))
②通知接收方:主題(存儲(chǔ))→XML元素(通知)→XML文檔(通知)→XSL顯示(含表單)
③通知接收方到反饋接收方: XSL顯示(含表單)→主題(存儲(chǔ))
④反饋接收方:主題(存儲(chǔ))→XML元素(反饋)→XML文檔(反饋)→XSL顯示(含表單)
⑤反饋發(fā)送方:表單數(shù)據(jù)→XML元素(反饋)→主題(存儲(chǔ))
系統(tǒng)組件模型如圖3:主題CWNFTopic是消息傳遞中介,NoticerServlet組件向發(fā)布用戶發(fā)送表單,并從表單接收數(shù)據(jù),然后生成XML元素對(duì)象,該元素對(duì)象和其它一些數(shù)據(jù)被作為參數(shù)調(diào)用PublisherBean組件方法,向主題發(fā)送以該元素對(duì)象為消息體的消息;ReaderServlet組件處理署名用戶和匿名用戶查閱通知的業(yè)務(wù),它從表單獲得用戶將查閱什么方面通知的有關(guān)信息后,便使用receive方法限時(shí)阻塞地從主題接收消息并對(duì)消息進(jìn)行篩選,把篩選出的若干消息的消息體取出,然后加工成XML文檔對(duì)象(根元素是通知集),最后輸出。FeedbackerPubServlet用于反饋發(fā)送方的業(yè)務(wù)處理,功能與NoticerServlet相似;FeedbackerSubServlet用于反饋接收方的業(yè)務(wù)處理,功能與ReaderServlet相似;PublisherBean組件被NoticerServlet組件和FeedbackerPubServlet組件調(diào)用,用于發(fā)送消息,容器管理發(fā)送事務(wù),具有很高的可靠性。
JDOM是一個(gè)開放源代碼的純Java樹式API,用于分析、建立、處理和序列化XML文檔。在數(shù)據(jù)流模型中,XML元素和XML文檔都由JDOM API建立,在發(fā)送方,通過用戶提交的表單取得名/值對(duì)若干,這些數(shù)據(jù)經(jīng)過JDOM方法處理生成XML元素對(duì)象,元素對(duì)象被作為消息的消息體發(fā)往主題存儲(chǔ);在接收方,持久訂閱者接收到若干XML元素對(duì)象后,繼續(xù)通過JDOM方法建立XML文檔對(duì)象。且XML文檔向Web瀏覽器輸出也依賴于JDOM的XMLOutputte對(duì)象方法:
XMLOutputter serializer=new XMLOutputter(); ... PrintWriter out=response.getWriter(); // out 是ServletResponse的輸出流對(duì)象 serializer.output(xmldoc,out); //通過out把XML文檔輸出到頁面 |
XSL是可擴(kuò)展的樣式單語言,通知集的XML文檔和反饋集的XML文檔都有相關(guān)的XSL文檔決定其頁面顯示,如通知集XML文檔的XSL樣式定義如下:
<?xml version="1.0" encoding="GBK"?> <xsl:stylesheet> <xsl:template match="/"> <HTML> <BODY> ... <DIV><xsl:apply-templates select="通知集"/></DIV> </BODY> </HTML> </xsl:template> <xsl:template match="通知集"> <xsl:for-each select="通知"> ... </xsl:for-each> </xsl:template> </xsl:stylesheet> |
用戶的一些處理工作需要注冊(cè)/登錄后才能進(jìn)行,因此注冊(cè)/登錄的獲準(zhǔn)信息必須能在有關(guān)Servlet組件之間傳遞。ServletContext 對(duì)象可設(shè)置和讀取屬性,使不同Servlet之間相互通信,在系統(tǒng)中被用于有關(guān)組件對(duì)用戶身份的驗(yàn)證。
每一條征求意見性通知都有一個(gè)相關(guān)聯(lián)的反饋集合,關(guān)聯(lián)可通過設(shè)置消息屬性實(shí)現(xiàn)。JMS消息(包括通知類消息)都有系統(tǒng)級(jí)JMSMessageID屬性,其值是唯一的,可用于表征每一條征求意見性通知,因此對(duì)任何反饋消息也可以設(shè)置一個(gè)應(yīng)用級(jí)屬性(CWNF中是FeedbackSN),讓它取與之相關(guān)聯(lián)的征求意見性通知的JMSMessageID屬性值。這樣就建立了兩者間的數(shù)據(jù)關(guān)聯(lián)。
因此數(shù)據(jù)流模型"③通知接收方到反饋接收方: XSL顯示(含表單)→主題(存儲(chǔ))"的實(shí)現(xiàn)流程如下:用戶在頁面上選擇一條征求意見性通知后,該通知的JMSMessageID屬性值將被傳遞給FeedbackerSubServlet組件,該組件將使用這個(gè)屬性值去匹配從主題取出的反饋消息的FeedbackSN屬性,從而篩選出相關(guān)聯(lián)的反饋消息。
那么一條征求意見性通知的JMSMessageID屬性值又如何傳遞給FeedbackerSubServlet組件呢?通過ServletContext對(duì)象只能傳遞可預(yù)知信息,CWNF的做法是:由XSL為每一條征求意見性通知設(shè)置一個(gè)獨(dú)立的表單,并把該通知的JMSMessageID屬性值寫在表單的TEXTAREA元素框內(nèi),這樣用戶在表單上選擇一條征求意見性通知后,該通知的JMSMessageID屬性值就隨表單一起提交給FeedbackerSubServlet組件。XSL有關(guān)代碼如下:
<xsl:if test="string(意見反饋)=‘on‘"> <FORM method="post" action="http://localhost:6888/Feedbacker/servlet /FeedbackerSubServlet"> <BUTTON type="submit">意見反饋</BUTTON> <TEXTAREA name="序列號(hào)" rows="1" cols="40"> <xsl:value-of select="序列號(hào)"/> </TEXTAREA> </FORM> </xsl:if> |
JMS應(yīng)用系統(tǒng)與數(shù)據(jù)庫系統(tǒng)有相似性,從數(shù)據(jù)方面看,JMS消息體的數(shù)據(jù)類型支持文本和對(duì)象,所以JMS更靈活,與XML集成應(yīng)用的空間更大;但從管理上看,JMS Provider向管理員提供的管理功能遠(yuǎn)遠(yuǎn)低于DBMS提供的管理功能,因此在面向Web的應(yīng)用中,JMS宜作為中小流量、管理員參與度較低的信息系統(tǒng)解決方案。
CWNF校務(wù)系統(tǒng)經(jīng)校園網(wǎng)實(shí)驗(yàn)性運(yùn)行,效果良好,驗(yàn)證了面向Web的JMS應(yīng)用是可行的。
聯(lián)系客服