Spring JMS 整合Weblogic JMS

2024-09-04 03:48
文章标签 java spring 整合 weblogic jms

本文主要是介绍Spring JMS 整合Weblogic JMS,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.1     JMS简介

       JMS的全称是Java Message Service,即Java消息服务。它主要用于在生产者和消费者之间进行消息传递,生产者负责产生消息,而消费者负责接收消息。把它应用到实际的业务需求中的话我们可以在特定的时候利用生产者生成一消息,并进行发送,对应的消费者在接收到对应的消息后去完成对应的业务逻辑。对于消息的传递有两种类型,一种是点对点的,即一个生产者和一个消费者一一对应;另一种是发布/订阅模式,即一个生产者产生消息并进行发送后,可以由多个消费者进行接收。

1.2     Spring整合JMS

       对JMS做了一个简要介绍之后,接下来就讲一下Spring整合JMS的具体过程。JMS只是一个标准,真正在使用它的时候我们需要有它的具体实现,这里我们就使用Weblogic的Weblogic JMS来作为它的实现。首先我们需要搭建一个Spring框架,并引用操作Weblogic JMS所需要的jar包。搭建Spring框架可以参考博客:https://blog.csdn.net/qq_36769100/article/details/70908148     ,Spirng框架依赖jar包下载地址:https://download.csdn.net/download/u013310119/10311191   。操作Weblogic JMS所需要的jar包下载地址为:https://download.csdn.net/download/u013310119/10311218       。搭建完成Spring框架,把Weblogic JMS的jar包导入后,就可以进行,Spring整合Weblogic JMS的开发。

在applicationContext.xml中配置Weblogic JMS的消息服务信息,队列,生参者,消费者和监听器信息。

<?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:context="http://www.springframework.org/schema/context"xmlns:jms="http://www.springframework.org/schema/jms"xmlns:jee="http://www.springframework.org/schema/jee"xmlns:tx="http://www.springframework.org/schema/tx"xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans-3.0.xsdhttp://www.springframework.org/schema/jeehttp://www.springframework.org/schema/jee/spring-jee-3.0.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context-3.0.xsdhttp://www.springframework.org/schema/txhttp://www.springframework.org/schema/tx/spring-tx-3.0.xsdhttp://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsdhttp://www.springframework.org/schema/jms http://www.springframework.org/schema/jms/spring-jms-3.0.xsd"><bean id="weblogicJms" class="org.springframework.jndi.JndiTemplate">  <property name="environment">  <props>  <prop key="java.naming.factory.initial">  weblogic.jndi.WLInitialContextFactory   </prop>  <prop key="java.naming.provider.url">  t3://10.19.22.94:7011  </prop>  <prop key="java.naming.factory.url.pkgs">  weblogic.jndi.factories  </prop>  <prop key="java.naming.security.principal">  <!--用户名 -->weblogic  </prop>  <prop key="java.naming.security.credentials"> <!--密码  -->weblogic123  </prop>  </props>  </property>  </bean>  <!-- Connection factory -->  <bean id="jmsConnectionFactory" class="org.springframework.jndi.JndiObjectFactoryBean">  <property name="jndiName" value="gt3.esb.jms.con.ESBConnectionFactory" />  <property name="jndiTemplate" ref="weblogicJms"/>  </bean>  <!-- 用来接受消息的消息队列 -->  <bean id="jmsQueue" class="org.springframework.jndi.JndiObjectFactoryBean">  <property name="jndiName" value="gt3.esb.jms.mdb.BaseQueueAsynMDBean" /> <property name="jndiTemplate" ref="weblogicJms"/> <!-- <delivery-params-overrides><priority>9</priority>优先级,0最小,9最大</delivery-params-overrides> 批量还是实时,0为实时,25,75,100为批量<messaging-performance-preference>0</messaging-performance-preference> --></bean>  <!-- 用来测试消息回复的 --><bean id="responseQueue" class="org.springframework.jndi.JndiObjectFactoryBean">  <property name="jndiName" value="responseQueue" />  <property name="jndiTemplate" ref="weblogicJms"/>  </bean>  <!-- Receiver --> <!--消息消费者 --> <!-- <bean id="jmsReceiver" class="com.inspur.JMS.service.QueueMsgReceiver1">  </bean> --><bean id="jmsReceiverJDBC" class="com.inspur.JDBCTemplate.listener.ConsumerMessageListener">  </bean>  <bean id="jmsReceiverRsponse" class="com.inspur.JMS.service.ConsumerMessageListener">  </bean>  <!-- Message Listener -->  <!-- 在Spring整合JMS的应用中,如果我们要进行本地的事务管理的话非常简单,只需要在定义对应的消息监听容器时指定其sessionTransacted属性为true,如:  <property name="sessionTransacted" value="true"/>    该属性值默认为false,这样JMS在进行消息监听的时候就会进行事务控制,当在接收消息时监听器执行失败时JMS就会对接收到的消息进行回滚--><!--   如果想接收消息和数据库访问处于同一事务中,那么我们就可以配置一个外部的事务管理同时配置一个支持外部事务管理的消息监听容器(如DefaultMessageListenerContainer)。要配置这样一个参与分布式事务管理的消息监听容器,我们可以配置一个JtaTransactionManager,当然底层的JMS ConnectionFactory需要能够支持分布式事务管理,并正确地注册我们的JtaTransactionManager。这样消息监听器进行消息接收和对应的数据库访问就会处于同一数据库控制下,当消息接收失败或数据库访问失败都会进行事务回滚操作。当给消息监听容器指定了transactionManager时,消息监听容器将忽略sessionTransacted的值。 --><bean id="listenerContainer"  class="org.springframework.jms.listener.DefaultMessageListenerContainer">  <property name="connectionFactory" ref="jmsConnectionFactory"/>  <property name="destination" ref="jmsQueue"/>  <!-- <property name="messageListener" ref="jmsReceiver"/>   --><property name="messageListener" ref="jmsReceiverRsponse"/>  <!--  <property name="transactionManager" ref="jtaTransactionManager"/>   --><property name="autoStartup" value="true"/>  <!-- 设置固定的线程数 -->  <property name="concurrentConsumers" value="6"></property>  <!-- 	设置动态的线程数   --><property name="concurrency" value="2-9"></property>  <!-- 设置最大的线程数 -->  <property name="maxConcurrentConsumers" value="15"></property> </bean><!--  <bean id="jtaTransactionManager" class="org.springframework.transaction.jta.JtaTransactionManager"/>  <tx:annotation-driven transaction-manager="jtaTransactionManager"/> --><!-- Spring JMS Template -->  <!--Spring提供了专门的jmsTemplate对消息队列进行操作--><bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate" lazy-init="true">  <property name="connectionFactory" ref="jmsConnectionFactory" />  <property name="defaultDestination" ref="jmsQueue" /><property name="receiveTimeout">  <value>5000</value>  </property>     </bean>  <!-- Sender -->  <!--生产者--><bean id="jmsSender" class="com.inspur.JMS.controller.SendJMSMessage"  lazy-init="true">  <property name="jmsTemplate" ref="jmsTemplate"></property>  </bean>  <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"><property name="dataSource" ref="dataSource"/></bean><!-- 数据源配置 --><!-- <jee:jndi-lookup jndi-name="JDBC Data Source-0" id="dataSource"/> --><bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"       destroy-method="close">      <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" />      <property name="url" value="jdbc:oracle:thin:@10.19.22.91:1521:orcl" />      <property name="username" value="ydpt" />      <property name="password" value="ydpt" />      </bean> <bean id="Student" class="entity.student">  <property name="name">  <value>Tom</value>  </property>  </bean>  <context:component-scan base-package="com.inspur" ><context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/></context:component-scan><!-- 配置spring注解扫描的包 -->    <context:component-scan base-package="com.elgin"></context:component-scan>    <!-- 或者不用注解的形式加载bean,改用配置的方式    <bean id="springWebService" class="com.elgin.spring.webservice.SpringWebServiceDemo ">      利用property可以对SpringService类进行初始化,比如<property name="name" value="姚明" /><property name="job" value="职业男篮" />,在配置完SpringService类后,就可以直接在程序中FileSystemXmlApplicationContext类或其他类似功能的类读取applicationContext.xml文件中的内容,并获得SpringService类的对象实例。但现在我们并不这样做,而是将SpringService类发布成WebService。在Tomcat的webapps项目中的WEB-INF\lib目录中有一个axis2-spring-1.4.1.jar文件, 该文件用于将被装配JavaBean的发布成WebService。  -->    </beans>

    接着我们来测试一下,看看我们的整合是否真的成功了,测试代码如下:

@Controller
@RequestMapping("test")
public class TestController {@Autowired@Qualifier("jmsQueue")private Destination destination;@Autowiredprivate ProducerServiceImpl producerService;@RequestMapping("first")public  String first() {producerService.sendMessage(destination, "你好,现在是:" + new Date().toLocaleString());return null;}}
@Component
public class ProducerServiceImpl  {@Autowiredprivate JmsTemplate jmsTemplate;public void sendMessage(Destination destination, final String message) {System.out.println("---------------生产者发送消息-----------------");System.out.println("---------------生产者发了一个消息:" + message);jmsTemplate.send(destination, new MessageCreator() {public Message createMessage(Session session) throws JMSException {/*TextMessage textMessage = session.createTextMessage(message);textMessage.setJMSReplyTo(responseDestination);return textMessage;*/return session.createTextMessage(message);/*MapMessage message = session.createMapMessage();message.setString("name1", "value1");message.setString("name2", "value2");message.setString("name3", "value3");return message;*/}});}public void sendMessage(final Destination destination, final Serializable obj) {//未使用MessageConverter的情况/*jmsTemplate.send(destination, new MessageCreator() {public Message createMessage(Session session) throws JMSException {ObjectMessage objMessage = session.createObjectMessage(obj);return objMessage;}});*///使用MessageConverter的情况jmsTemplate.convertAndSend(destination, obj);jmsTemplate.execute(new SessionCallback<Object>() {public Object doInJms(Session session) throws JMSException {MessageProducer producer = session.createProducer(destination);Message message = session.createObjectMessage(obj);producer.send(message);return null;}});jmsTemplate.execute(new ProducerCallback<Object>() {public Object doInJms(Session session, MessageProducer producer)throws JMSException {Message message = session.createObjectMessage(obj);producer.send(destination, message);return null;}});}}

消费者

public class ConsumerMessageListener implements MessageListener {


@Autowired
private TestDao testDao;

private int count = 0;

public void onMessage(Message message) {
//这里我们知道生产者发送的就是一个纯文本消息,所以这里可以直接进行强制转换,或者直接把onMessage方法的参数改成Message的子类TextMessage

System.out.println("在onMessage中线程ID是"+Thread.currentThread());  
TextMessage textMsg = (TextMessage) message;



System.out.println(new Date().toLocaleString() + "接收到一个纯文本消息。");
try {
String text = textMsg.getText();
System.out.println("消息内容是:" + text);

} catch (JMSException e) {
e.printStackTrace();
}
}


}

测试结果如下:


下面提供demo源码下载地址:

https://download.csdn.net/download/u013310119/10311333


这篇关于Spring JMS 整合Weblogic JMS的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1134915

相关文章

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

Springboot @Autowired和@Resource的区别解析

《Springboot@Autowired和@Resource的区别解析》@Resource是JDK提供的注解,只是Spring在实现上提供了这个注解的功能支持,本文给大家介绍Springboot@... 目录【一】定义【1】@Autowired【2】@Resource【二】区别【1】包含的属性不同【2】@

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

Elasticsearch 在 Java 中的使用教程

《Elasticsearch在Java中的使用教程》Elasticsearch是一个分布式搜索和分析引擎,基于ApacheLucene构建,能够实现实时数据的存储、搜索、和分析,它广泛应用于全文... 目录1. Elasticsearch 简介2. 环境准备2.1 安装 Elasticsearch2.2 J

Java中的String.valueOf()和toString()方法区别小结

《Java中的String.valueOf()和toString()方法区别小结》字符串操作是开发者日常编程任务中不可或缺的一部分,转换为字符串是一种常见需求,其中最常见的就是String.value... 目录String.valueOf()方法方法定义方法实现使用示例使用场景toString()方法方法

Java中List的contains()方法的使用小结

《Java中List的contains()方法的使用小结》List的contains()方法用于检查列表中是否包含指定的元素,借助equals()方法进行判断,下面就来介绍Java中List的c... 目录详细展开1. 方法签名2. 工作原理3. 使用示例4. 注意事项总结结论:List 的 contain

Java实现文件图片的预览和下载功能

《Java实现文件图片的预览和下载功能》这篇文章主要为大家详细介绍了如何使用Java实现文件图片的预览和下载功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... Java实现文件(图片)的预览和下载 @ApiOperation("访问文件") @GetMapping("

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis