spring监听与IBM MQ JMS整合
spring xml 的配置:
文件名:applicationContext-biz-mq.xml
- <?xml version="1.0" encoding="UTF-8"?>
- <beans xmlns="http://www.springframework.org/schema/beans"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xmlns:tx="http://www.springframework.org/schema/tx"
- xmlns:jms="http://www.springframework.org/schema/jms"
- xmlns:aop="http://www.springframework.org/schema/aop"
- xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
- http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
- http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
- http://www.springframework.org/schema/jms http://www.springframework.org/schema/jms/spring-jms-3.0.xsd ">
- <description>MQ</description>
- <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
- <property name="locations">
- <list>
- <value>classpath:/mqconnect.properties</value>
- </list>
- </property>
- <property name="ignoreUnresolvablePlaceholders" value="true" />
- </bean>
- <!-- 业务实现类 -->
- <bean id="callRecordBiz" class="com.zmcc.servicemanager.biz.impl.CallRecordBizImpl" autowire="byName"/>
- <!-- <bean id="mqMessageSend" class="com.zmcc.servicemanager.mq.MQMessageSend">
- jie
- <property name="queueManagerName" value="${queue.manager.send}" />
- <property name="host" value="${queue.manager.host.send}" />
- <property name="destinationName" value="${queue.name.send}" />
- </bean>
- <bean id="mqMessageReceiveListener" class="com.zmcc.servicemanager.mq.MQMessageReceiveListener" init-method="start">
- 接收方队列管理器名
- <property name="queueManagerName" value="${queue.manager.get}" />
- <property name="host" value="${queue.manager.host.get}" />
- <property name="destinationName" value="${queue.name.get}" />
- </bean> -->
- <!-- WebSphere MQ Connection Factory -->
- <bean id="mqConnectionFactory" class="com.ibm.mq.jms.MQConnectionFactory">
- <property name="hostName" value="${queue.manager.host.get}"/>
- <property name="queueManager" value="${queue.manager.get}"/>
- <property name="channel" value="${app.mq.channel}"/>
- <property name="port" value="${app.mq.port}"/>
- <property name="transportType" value="${app.mq.transportType}"/>
- </bean>
- <!-- JMS Queue Connection Factory -->
- <bean id="transactionManager" class="org.springframework.jms.connection.JmsTransactionManager">
- <property name="connectionFactory" ref="mqConnectionFactory"/>
- </bean>
- <!-- JMS Destination Resolver -->
- <!-- <bean id="jmsDestinationResolver" class="org.springframework.jms.support.destination.DynamicDestinationResolver" /> -->
- <bean id="messageConverter" class="com.zmcc.servicemanager.mq.spring.MessageConverter" />
- <!-- 定义接收者 -->
- <bean id="messageListener" class="com.zmcc.servicemanager.mq.spring.MessageListener" >
- <property name="callRecordBiz" ref="callRecordBiz" />
- </bean>
- <!-- JMS listener -->
- <!-- <bean id="messageListenerAdapter" class="org.springframework.jms.listener.adapter.MessageListenerAdapter">
- <property name="defaultListenerMethod" value="receviedMessage"/>
- <property name="messageConverter" ref="messageConverter"/>
- <property name="delegate" ref="messageListener"/>
- </bean> -->
- <!--
- JMS listener
- listener:org.springframework.jms.listener.adapter.MessageListenerAdapter
- message-converter="messageConverter",
- -->
- <jms:listener-container connection-factory="mqConnectionFactory" transaction-manager="transactionManager"
- message-converter="messageConverter">
- <jms:listener destination="${queue.name.get}" ref="messageListener" method="receviedMessage" />
- </jms:listener-container>
- </beans>
mqconnect.properties配置文件:
- #通道名
- app.mq.channel=SYSTEM.DEF.SVRCONN
- #传输类型
- app.mq.transportType=1
- #端口号
- app.mq.port=1414
- #队列管理器名称-发送方
- queue.manager.send=WMQ1QM
- #主机地址-发送方
- queue.manager.host.send=10.70.175.81
- #队列名称-发送方
- queue.name.send=WMQ1OutputQ
- #队列管理器名称--接收方
- queue.manager.get=WMQ2QM
- #主机地址--接收方
- queue.manager.host.get=10.70.175.82
- #队列名称--接收方
- queue.name.get=WMQ2InputQ
MessageTest.Java测试文件,用来启动接收监听的配置文件:
- import org.springframework.context.support.ClassPathXmlApplicationContext;
- public class MessageTest {
- /**
- * @param args
- */
- public static void main(String[] args) {
- new ClassPathXmlApplicationContext("classpath*:/applicationContext-biz-mq.xml");
- }
- }
MessageListener.java监听文件:
- import com.zmcc.servicemanager.biz.CallRecordBiz;
- import com.zmcc.servicemanager.domain.CallRecord;
- /**
- * 消息监听器
- * @author ZouXia
- *
- */
- public class MessageListener{
- private CallRecordBiz callRecordBiz;
- /**
- * 接收消息
- * @param callRecord
- */
- public void receviedMessage(CallRecord callRecord) {
- System.out.println(callRecord.getRequestContent());
- // callRecordBiz.saveEntity(callRecord);
- }
- public CallRecordBiz getCallRecordBiz() {
- return callRecordBiz;
- }
- public void setCallRecordBiz(CallRecordBiz callRecordBiz) {
- this.callRecordBiz = callRecordBiz;
- }
- }
MessageConverter.java用来转换的类:
- import javax.jms.JMSException;
- import javax.jms.Message;
- import javax.jms.Session;
- import javax.jms.TextMessage;
- import org.springframework.jms.support.converter.MessageConversionException;
- import com.zmcc.servicemanager.domain.CallRecord;
- /**
- * 消息转换器
- * @author ZouXia
- *
- */
- public class MessageConverter implements org.springframework.jms.support.converter.MessageConverter {
- /**
- * 发送消息的转换
- */
- public Message toMessage(Object object, Session session) throws JMSException, MessageConversionException {
- return null;
- }
- /**
- * 接收消息的转换
- */
- public Object fromMessage(Message message) throws JMSException,MessageConversionException {
- // TODO
- TextMessage mapMessage = (TextMessage) message;
- CallRecord callRecord = new CallRecord();
- callRecord.setEndTime(new Date());
- callRecord.setRequestContent(mapMessage.getText());
- return callRecord;
- }
- }
CallRecord.java实体类
- public class CallRecord implements Serializable{
- private static final long serialVersionUID = 1L;
- private String requestContent;
- private Date endTime;
- ……
- }
JmsProducer.java发送消息:
- import javax.jms.Connection;
- import javax.jms.Destination;
- import javax.jms.JMSException;
- import javax.jms.MessageProducer;
- import javax.jms.Session;
- import javax.jms.TextMessage;
- import com.ibm.mq.jms.JMSC;
- import com.ibm.mq.jms.MQQueueConnectionFactory;
- /**
- * 点对点模式
- * @author ZouXia
- *
- */
- public class JmsProducer {
- /**
- * Main method
- *
- * @param args
- */
- public static void main(String[] args) {
- // Variables
- Connection connection = null;
- Session session = null;
- Destination destination = null;
- MessageProducer producer = null;
- try {
- // Create a connection factory
- // objects
- MQQueueConnectionFactory factory = new MQQueueConnectionFactory();
- factory.setQueueManager("WMQ1QM");
- factory.setHostName("10.70.175.81");
- factory.setTransportType(JMSC.MQJMS_TP_CLIENT_MQ_TCPIP);
- factory.setPort(1414);
- factory.setChannel("SYSTEM.DEF.SVRCONN");
- // Create JMS objects
- connection = factory.createConnection();
- session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
- destination = session.createQueue("WMQ1OutputQ");
- producer = session.createProducer(destination);
- long uniqueNumber = System.currentTimeMillis() % 1000;
- TextMessage message = session
- .createTextMessage("JmsProducer: Your lucky number today is " + uniqueNumber);
- // Start the connection
- connection.start();
- // And, send the message
- producer.send(message);
- System.out.println("Sent message:\n" + message);
- } catch (JMSException jmsex) {
- jmsex.fillInStackTrace();
- } finally {
- try {
- producer.close();
- session.close();
- connection.close();
- } catch (JMSException e) {
- e.printStackTrace();
- }
- }
- }
- }
所对应的发送方WMQ1QM的资源管理器:
所对应的通道:
接收方WMQ2QM的队列:
通道:
资源管理器即IBM MQ explorer是基于eclipse的进行的,在eclipse里面添加plug插件即可,其更新地址为:
http://public.dhe.ibm.com/software/integration/wmq/explorer/v75/updates/
- Exception in thread "main" java.lang.NoClassDefFoundError: javax/resource/ResourceException
- at com.ibm.mq.MQEnvironment.<clinit>(MQEnvironment.java:490)
- at com.ibm.mq.jms.services.ConfigEnvironment.<clinit>(ConfigEnvironment.java:190)
- at java.lang.Class.forName0(Native Method)
- at java.lang.Class.forName(Class.java:247)
- at com.ibm.mq.jms.MQConnectionFactory$1.run(MQConnectionFactory.java:658)
- at java.security.AccessController.doPrivileged(Native Method)
- at com.ibm.mq.jms.MQConnectionFactory.<clinit>(MQConnectionFactory.java:651)
- at com.zmcc.servicemanager.mq.jms.JmsProducer.main(JmsProducer.java:36)
- Caused by: java.lang.ClassNotFoundException: javax.resource.ResourceException
- at java.net.URLClassLoader$1.run(URLClassLoader.java:200)
- at java.security.AccessController.doPrivileged(Native Method)
- at java.net.URLClassLoader.findClass(URLClassLoader.java:188)
- at java.lang.ClassLoader.loadClass(ClassLoader.java:307)
- at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
- at java.lang.ClassLoader.loadClass(ClassLoader.java:252)
- at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:320)
- ... 8 more
- <dependency>
- <groupId>javax.resource</groupId>
- <artifactId>connector</artifactId>
- <version>1.0</version>
- </dependency>
spring监听与IBM MQ JMS整合的更多相关文章
- spring中配置监听队列的MQ
一.spring中配置监听队列的MQ相关信息注:${}是读取propertites文件的常量,这里忽略.绿色部分配置在接收和发送端都要配置. <bean id="axx" ...
- ActiveMQ监听消息并进行转发,监听不同的mq服务器和不同的队列
工作中刚接触mq消息业务,其实也就是监听一下别的项目发送的消息然后进行对应的转发,但是监听的mq会有多个,而且转发的地址也可能有多个,这里就使用spring集成的方式!记录一下实现方式: 监听多个mq ...
- spring监听机制——观察者模式的应用
使用方法 spring监听模式需要三个组件: 1. 事件,需要继承ApplicationEvent,即观察者模式中的"主题",可以看做一个普通的bean类,用于保存在事件监听器的业 ...
- Spring 监听
Spring 中的事件监听的实现 这里我们不讨论事件监听的机制的原理,我们只讨论如何在项目中实现时间监听. spring的事件监听是基于观察者模式.设计开发中.如下类与接口是我们必须要使用的. App ...
- Spring监听,ApplicationListener
import java.util.HashMap; import java.util.Map; import org.apache.commons.lang3.StringUtils; import ...
- SpringBoot 对IBM MQ进行数据监听接收以及数据发送
一.需求介绍 后端使用Spring Boot2.0框架,要实现IBM MQ的实时数据JMS监听接收处理,并形成回执通过MQ队列发送. 二.引入依赖jar包 <dependency> < ...
- IBM MQ 与spring的整合
文件名:applicationContext-biz-mq.xml 新浪博客把里面的代码全部转换成HTML了,所以无法粘贴 可以查看CSDN里面的:http://blog.csdn.net/xiazo ...
- IBM Mq Spring JMS 的xml配置
<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.spr ...
- IBM MQ 集成CXF 发送JMS 消息
0.POM依赖 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w ...
随机推荐
- JSON Web Token的使用(转载)
定义 JSON Web Token(JWT)是一个非常轻巧的规范.这个规范允许我们使用JWT在用户和服务器之间传递安全可靠的信息. 适用场景 1.用于向Web应用传递一些非敏感信息.例如完成加好友.下 ...
- sqoop操作之ETL小案例
Extraction-Transformation-Loading的缩写,中文名称为数据提取.转换和加载.将数据从ORACLE中抽取数据,经过hive进行分析转换,最后存放到ORACLE中去. 本案例 ...
- python之路07文件处理
一 操作文件的方法: f.read() #读取所有内容,光标移动到文件末尾 f.readline() #读取一行内容,光标移动到第二行首部 f.readlines() #读取每一行内容,存放于列 ...
- Spring 学习之AOP
1. 走进面前切面编程 编程范式: 面向过程编程,c语言: 面向对象编程:c++,java,c#; 函数式编程: 事件驱动编程: 面向切面编程: AOP是一种编程范式,不是编程语言:解决特定问题,不能 ...
- HTML5 新特性(一)
1. 新的Doctype 尽管使用<!DOCTYPE html>,即使浏览器不懂这句话也会按照标准模式去渲染 2. Figure元素 用<figure>和<figcapt ...
- LRU的理解与Java实现
简介 LRU(Least Recently Used)直译为"最近最少使用".其实很多老外发明的词直译过来对于我们来说并不是特别好理解,甚至有些词并不在国人的思维模式之内,比如快速 ...
- 用strings命令查看kafka-log内容 过滤二进制编码
kafka的log内容格式还不没怎么了解,想快速浏览消息内容的话,除了使用它自带的kafka-console-consumer.sh脚本,还可以直接去看log文件本身,不过内容里有部分二进制字符,通过 ...
- leetcode453
public class Solution { public int MinMoves(int[] nums) { var list = nums.OrderBy(x => x).ToList( ...
- 18.OGNL与ValueStack(VS)-值栈入门
转自:https://wenku.baidu.com/view/84fa86ae360cba1aa911da02.html 下面我们建立struts2ognl项目来练习ognl的使用. 步骤一.搭建s ...
- 异常信息ASM ClassReader failed to parse class file的问题解决
jdk8与spring 3不兼容问题:用jdk7.或者升级到spring4 详情:异常信息ASM ClassReader failed to parse class file的问题解决