Activemq和Lingo實現JMS和非同步呼叫(轉)
Activemq和Lingo實現JMS和非同步呼叫(轉)[@more@] jms是大家在專案中經常用到的技術,而activemq又是開源的jms產品中比較優秀的。在應用JMS處理相關業務時,大家都是構造訊息,然後傳送到佇列,最後用message監聽器監聽到訊息,對訊息進行分析處理。在這個過程中,有兩步是比較麻煩和重複的,那就是構造訊息和拆解訊息。並且這樣與物件導向的思想很是違背。如果這樣做顯然是面向訊息資料的,而不是物件導向的。基於以上原因,我向大家介紹一個我在專案中經過實踐的開源框架:lingo. lingo在JMS中起的主要作用就是對訊息的封裝,它讓你可以不必關心訊息的構造和拆解,而只需關心你本身的業務邏輯。我將舉一個例子,分別用activemq直接實現和用lingo實現。在這個例子中我用到了spring framework. =================================Hello.java=========================== import java.io.Serializable; /**Hello.java用來傳遞JAVA物件 * Author: cjp * Date: 2005-11-8 * Time: 22:24:02 */ public class Hello implements Serializable { private String id; private Hello hello; private PointList pointList; public String getId() { return id; } public void setId(String id) { this.id = id; } public Hello getHello() { return hello; } public void setHello(Hello hello) { this.hello = hello; } } =========================SpringTest .java======================== import org.springframework.jms.core.JmsTemplate; import org.springframework.jms.core.MessageCreator; import org.springframework.test.AbstractDependencyInjectionSpringContextTests; import javax.jms.*; /** *傳送JMS訊息 */ public class SpringTest extends AbstractDependencyInjectionSpringContextTests { protected String[] getConfigLocations() { return new String[]{"file:D:wosame estcomwosame
oomjmsjms.xml"}; } public void testSendMessage() throws Exception { JmsTemplate jmsTemplate = (JmsTemplate) applicationContext.getBean("jmsTemplate"); jmsTemplate.send(new MessageCreator() { public Message createMessage(Session session) throws JMSException { ObjectMessage message=session.createObjectMessage(); Hello hello=new Hello(); hello.setId("test"); message.setObject(hello); return message; } }); } } ================================HelloMDP .java================================== /** 處理JMS訊息 */ import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import javax.jms.*; public class HelloMDP implements MessageListener { protected Log log = LogFactory.getLog(HelloMDP.class); public void onMessage(Message message) { try { ObjectMessage objMessage = (ObjectMessage) message; Hello hello= (Hello) objMessage.getObject(); System.out.println("hello.getId() = " + hello.getId()); } catch (JMSException e) { log.error("Parse failed", e); } } } ================================jms.xml================================== P> ""> <!--嵌入式的JMS連線,也就是跟隨JVM一起啟動,可以參看activemq的文件--> <!--訊息監聽器,也就是訊息的具體的處理器--> <!--jms監聽需要JTA容器的支援--> <!--訊息的消費者,也就是將監聽器與具體的佇列關聯--> <!--spring的JMS template,用來傳送JMS訊息到指定的佇列-->
·上一篇:·下一篇:
最新更新 | ||
·······WeblogicServer9新特性:J2EELibraries···················使用訊息驅動Beans(3)···· |
| ||
| | | | | | | | ||
| ||
Copyright © 2004 - 2007 All Rights Reserved
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/8225414/viewspace-968179/,如需轉載,請註明出處,否則將追究法律責任。
請登入後發表評論
登入
全部評論
|
相關文章
- activeMQ JMS監控配置MQ
- jmeter之——jms壓測(activemq)JMeterMQ
- 同步、非同步、阻塞和非阻塞非同步
- 非同步和非阻塞非同步
- ♻️同步和非同步;並行和併發;阻塞和非阻塞非同步並行
- ActiveMQ第二彈:使用Spring JMS與ActiveMQ通訊MQSpring
- Socket程式設計中的同步、非同步、阻塞和非阻塞(轉)程式設計非同步
- activeMQ JMS JConsole監控MQ
- Java實現非同步呼叫Java非同步
- Node中非同步和同步的實現非同步
- 非同步呼叫和同步呼叫 及 spring的@Async註解非同步Spring
- 求助:JMS的實現
- Java 非阻塞 IO 和非同步 IOJava非同步
- ActiveMq 之JMS 看這一篇就夠了MQ
- webservice和jms的區別Web
- ActiveMq安裝和使用MQ
- [轉]阻塞/非阻塞與同步/非同步非同步
- 教你如何用 Java 實現非同步呼叫Java非同步
- web service實現原理與非同步呼叫Web非同步
- python中非同步非阻塞如何實現Python非同步
- python和C的如何實現互相呼叫?Python
- C# 實現 gRPC 服務和呼叫C#RPC
- Activemq和Rabbitmq埠衝突MQ
- 教你實現快應用storage介面同步呼叫
- mysql和redis實時同步資料怎麼實現MySqlRedis
- 基於rust實現的事件系統,支援同步和非同步Rust事件非同步
- nacos實現Java和.NetCore的服務註冊和呼叫JavaNetCore
- TManagedDataSet和DataSetPool的實現 (轉)
- 對執行緒、協程和同步非同步、阻塞非阻塞的理解執行緒非同步
- 用opencv實現的PCA演算法,非API呼叫OpenCVPCA演算法API
- python呼叫外部子程式,通過管道實現非同步標準輸入和輸出的Python非同步
- 怎樣透過HTTP來呼叫JMSHTTP
- CTI技術和呼叫中心 (轉)
- ActiveMQ + Camel 實現訊息路由MQ路由
- C++非同步呼叫利器future/promise實現原理C++非同步Promise
- 圖的深度優先遍歷(堆疊實現和非堆疊實現)
- 轉享:JavaScript非同步實現JavaScript非同步
- 《JAVA併發程式設計實戰》原子變數和非阻塞同步機制Java程式設計變數