ActiveMQ整合Spring框架

简介: 前面文章介绍了ActiveMQ的相关内容,本文介绍ActiveMQ和Spring的整合开发

前面文章介绍了ActiveMQ的相关内容,本文介绍ActiveMQ和Spring的整合开发

整合Spring框架

1.相关jar包

activemq-all-5.9.0.jar
aopalliance-1.0.jar
commons-logging-1.2.jar
spring-aop-4.1.6.RELEASE.jar
spring-beans-4.1.6.RELEASE.jar
spring-context-4.1.6.RELEASE.jar
spring-core-4.1.6.RELEASE.jar
spring-expression-4.1.6.RELEASE.jar
spring-jms-4.1.6.RELEASE.jar
spring-messaging-4.1.6.RELEASE.jar
spring-tx-4.1.6.RELEASE.jar
spring-web-4.1.6.RELEASE.jar
xbean-spring-4.5.jar

相关maven坐标

<dependencies>
  <!-- ActiveMQ客户端完整jar包依赖 -->
  <dependency>
    <groupId>org.apache.activemq</groupId>
    <artifactId>activemq-all</artifactId>
    <version>5.9.0</version>
  </dependency>
  <!-- ActiveMQ和Spring整合配置文件标签处理jar包依赖 -->
  <dependency>
    <groupId>org.apache.xbean</groupId>
    <artifactId>xbean-spring</artifactId>
    <version>4.5</version>
  </dependency>
  <!-- Spring-JMS插件相关jar包依赖 -->
  <dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-jms</artifactId>
    <version>4.1.6.RELEASE</version>
  </dependency>
  <!-- Spring框架上下文jar包依赖 -->
  <dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-context</artifactId>
    <version>4.1.6.RELEASE</version>
  </dependency>
</dependencies>

2.定义消费者

package com.dpb.consumer;
import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.ObjectMessage;
import com.dpb.bean.Order;
/**
 * ActiveMQ Consumer消费者
 * @author dengp
 *
 */
public class OrderConsumer implements MessageListener{
  @Override
  public void onMessage(Message message) {
    try{
      ObjectMessage objectMassage = (ObjectMessage) message;
      Order order = (Order) objectMassage.getObject();
      System.out.println("the order is : " + order);
    }catch(Exception e){
      e.printStackTrace();
    }
  }
}

3.定义生产者

package com.dpb.producer;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.ObjectMessage;
import javax.jms.Session;
import org.springframework.jms.core.JmsTemplate;
import org.springframework.jms.core.MessageCreator;
import com.dpb.bean.Order;
/**
 * ActiveMQ producer 生产者
 * @author dengp
 *
 */
public class OrderProducer {
  private JmsTemplate template;
  public JmsTemplate getTemplate() {
    return template;
  }
  public void setTemplate(JmsTemplate template) {
    this.template = template;
  }
  /**
   * 生产者发送消息
   * @param destinationName  目的地名称
   * @param order  需要发送的订单数据
   */
  public void sendOrder(String destinationName, Order order){
    try{
      template.send(destinationName, new MessageCreator() {
        /**
         * 通过模板模式暴露的方法设置发送的信息
         */
        @Override
        public Message createMessage(Session session) throws JMSException {
          ObjectMessage objectMessage = session.createObjectMessage(order);
          return objectMessage;
        }
      });
    }catch(Exception e){
      e.printStackTrace();
      throw new RuntimeException("send order to MQ server error!!");
    }
  }
}

4.Spring配置文件整合ActiveMQ

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
  xmlns:context="http://www.springframework.org/schema/context"
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
  xmlns:amq="http://activemq.apache.org/schema/core"
  xmlns:jms="http://www.springframework.org/schema/jms"
  xsi:schemaLocation="http://www.springframework.org/schema/beans     
        http://www.springframework.org/schema/beans/spring-beans-4.0.xsd     
        http://www.springframework.org/schema/context     
        http://www.springframework.org/schema/context/spring-context-4.0.xsd  
        http://www.springframework.org/schema/jms  
        http://www.springframework.org/schema/jms/spring-jms-4.0.xsd  
        http://activemq.apache.org/schema/core  
        http://activemq.apache.org/schema/core/activemq-core-5.9.0.xsd">
    <!-- 添加扫描 -->
  <context:component-scan base-package="com.dpb.*"></context:component-scan>
  <!-- ActiveMQ 连接工厂 -->
  <!-- 真正可以产生Connection的ConnectionFactory,由对应的 JMS服务厂商提供 -->
  <!-- 需提供访问路径tcp://ip:61616;以及用户名,密码 -->
  <amq:connectionFactory id="amqConnectionFactory"
    brokerURL="tcp://192.168.88.121:61616" userName="admin" password="admin" />
  <!-- Spring Caching连接工厂 -->
  <!-- Spring用于管理真正的ConnectionFactory的ConnectionFactory -->
  <bean id="connectionFactory"
    class="org.springframework.jms.connection.CachingConnectionFactory">
    <!-- 目标ConnectionFactory对应真实的可以产生JMS Connection的ConnectionFactory -->
    <property name="targetConnectionFactory" ref="amqConnectionFactory"></property>
    <!-- Session缓存数量 -->
    <property name="sessionCacheSize" value="100" />
  </bean>
  <!-- 消息生产者 start -->
  <!-- 定义JmsTemplate对象. 此类型由Spring框架JMS组件提供. 用于访问ActiveMQ使用. -->
  <bean id="jmsQueueTemplate" class="org.springframework.jms.core.JmsTemplate">
    <!-- 这个connectionFactory对应的是我们定义的Spring提供的那个ConnectionFactory对象 -->
    <constructor-arg ref="connectionFactory" />
    <!-- 非pub/sub模型(发布/订阅),即队列模式, 默认数据可省略配置 -->
    <!-- <property name="pubSubDomain" value="false" /> -->
  </bean>
  <!-- 定义生成者对象 -->
  <bean id="orderProducer" class="com.dpb.producer.OrderProducer">
    <!-- 为属性赋值 -->
    <property name="template" ref="jmsQueueTemplate"></property>
  </bean>
  <!--消息生产者 end -->
  <!-- 消息消费者 start -->
  <!-- 定义消息监听器, 此组件为spring-jms组件定义. 可以一次注册若干消息监听器.
    属性解释:
      destination-type - 目的地类型, queue代表消息队列
        可选值: queue | topic | durableTopic
        queue - 默认值. 代表消息队列
        topic - 代表消息队列集合
        durableTopic - 持久化的消息队列集合. ActiveMQ会保证消息的消费者一定接收到此消息.
      container-type - 容器类型
        可选值: default | simple
        default - 默认值. 默认容器类型, 对应DefaultMessageListenerContainer
        simple - 简单容器类型, 对应SimpleMessageListenerContainer
      connection-factory - 链接工厂, 注入的是Spring-JMS组件提供的链接工厂对象.
      acknowledge - 确认方式
        可选值: auto | client | dups-ok | transacted
        auto - 默认值, 即自动确认消息
        client - 客户端确认消息
        dups-ok - 可使用副本的客户端确认消息
        transacted - 有事务的持久化消息确认机制. 需开启对ActiveMQ的事务控制才可应用. 
   -->
  <jms:listener-container destination-type="queue"
    container-type="default" connection-factory="connectionFactory"
    acknowledge="auto">
    <!-- 注册消息监听器. 如果需要注册多个, 重复定义下述标签. -->
    <jms:listener destination="test-spring" ref="orderReciver" />
  </jms:listener-container>
  <!-- 容器管理消息监听器实现类对象 -->
  <bean id="orderReciver" class="com.dpb.consumer.OrderConsumer"/>
  <!-- 消息消费者 end -->
</beans>

5.测试

public class Test {
  public static void main(String[] args) {
    ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml");
    OrderProducer pro = ac.getBean("orderProducer",OrderProducer.class);
    Order order = new Order();
    order.setId("101");
    order.setNick("波波烤鸭");
    order.setPrice(10000L);
    order.setCreateTime(new Date());
    pro.sendOrder("test-spring", order);
  }
}


20190216221848981.png20190216221909412.png

相关文章
|
1月前
|
前端开发 Java 物联网
智慧班牌源码,采用Java + Spring Boot后端框架,搭配Vue2前端技术,支持SaaS云部署
智慧班牌系统是一款基于信息化与物联网技术的校园管理工具,集成电子屏显示、人脸识别及数据交互功能,实现班级信息展示、智能考勤与家校互通。系统采用Java + Spring Boot后端框架,搭配Vue2前端技术,支持SaaS云部署与私有化定制。核心功能涵盖信息发布、考勤管理、教务处理及数据分析,助力校园文化建设与教学优化。其综合性和可扩展性有效打破数据孤岛,提升交互体验并降低管理成本,适用于日常教学、考试管理和应急场景,为智慧校园建设提供全面解决方案。
242 70
|
13天前
|
Java 开发者 Spring
Spring框架 - 深度揭秘Spring框架的基础架构与工作原理
所以,当你进入这个Spring的世界,看似一片混乱,但细看之下,你会发现这里有个牢固的结构支撑,一切皆有可能。不论你要建设的是一座宏大的城堡,还是个小巧的花园,只要你的工具箱里有Spring,你就能轻松搞定。
57 6
|
1月前
|
Java Spring
Spring框架的学习与应用
总的来说,Spring框架是Java开发中的一把强大的工具。通过理解其核心概念,通过实践来学习和掌握,你可以充分利用Spring框架的强大功能,提高你的开发效率和代码质量。
79 20
|
3月前
|
存储 人工智能 开发框架
Spring AI Alibaba 应用框架挑战赛圆满落幕,恭喜获奖选手
第二届开放原子大赛 Spring AI Alibaba 应用框架挑战赛决赛于 2 月 23 日在北京圆满落幕。
195 31
|
3月前
|
前端开发 Java 数据库连接
Spring框架初识
Spring 是一个分层的轻量级开源框架,核心功能包括控制反转(IOC)和面向切面编程(AOP)。主要模块有核心容器、Spring 上下文、AOP、DAO、ORM、Web 模块和 MVC 框架。它通过 IOC 将配置与代码分离,简化开发;AOP 提供了声明性事务管理等增强功能。
114 21
Spring框架初识
|
2月前
|
消息中间件 存储 Java
微服务——SpringBoot使用归纳——Spring Boot中集成ActiveMQ——ActiveMQ安装
本教程介绍ActiveMQ的安装与基本使用。首先从官网下载apache-activemq-5.15.3版本,解压后即可完成安装,非常便捷。启动时进入解压目录下的bin文件夹,根据系统选择win32或win64,运行activemq.bat启动服务。通过浏览器访问`http://127.0.0.1:8161/admin/`可进入管理界面,默认用户名密码为admin/admin。ActiveMQ支持两种消息模式:点对点(Queue)和发布/订阅(Topic)。前者确保每条消息仅被一个消费者消费,后者允许多个消费者同时接收相同消息。
76 0
微服务——SpringBoot使用归纳——Spring Boot中集成ActiveMQ——ActiveMQ安装
|
2月前
|
前端开发 Java 数据库连接
Spring MVC 扩展和SSM框架整合
通过以上步骤,我们可以将Spring MVC扩展并整合到SSM框架中。这个过程包括配置Spring MVC和Spring的核心配置文件,创建控制器、服务层和MyBatis的Mapper接口及映射文件。在实际开发中,可以根据具体业务需求进行进一步的扩展和优化,以构建更加灵活和高效的企业级应用程序。
71 5
|
4月前
|
SQL Java 数据库连接
对Spring、SpringMVC、MyBatis框架的介绍与解释
Spring 框架提供了全面的基础设施支持,Spring MVC 专注于 Web 层的开发,而 MyBatis 则是一个高效的持久层框架。这三个框架结合使用,可以显著提升 Java 企业级应用的开发效率和质量。通过理解它们的核心特性和使用方法,开发者可以更好地构建和维护复杂的应用程序。
223 29
|
2月前
|
消息中间件 Java 微服务
微服务——SpringBoot使用归纳——Spring Boot中集成ActiveMQ——发布/订阅消息的生产和消费
本文详细讲解了Spring Boot中ActiveMQ的发布/订阅消息机制,包括消息生产和消费的具体实现方式。生产端通过`sendMessage`方法发送订阅消息,消费端则需配置`application.yml`或自定义工厂以支持topic消息监听。为解决点对点与发布/订阅消息兼容问题,可通过设置`containerFactory`实现两者共存。最后,文章还提供了测试方法及总结,帮助读者掌握ActiveMQ在异步消息处理中的应用。
109 0
|
2月前
|
消息中间件 网络协议 Java
微服务——SpringBoot使用归纳——Spring Boot中集成ActiveMQ——ActiveMQ集成
本文介绍了在 Spring Boot 中集成 ActiveMQ 的详细步骤。首先通过引入 `spring-boot-starter-activemq` 依赖并配置 `application.yml` 文件实现基本设置。接着,创建 Queue 和 Topic 消息类型,分别使用 `ActiveMQQueue` 和 `ActiveMQTopic` 类完成配置。随后,利用 `JmsMessagingTemplate` 实现消息发送功能,并通过 Controller 和监听器实现点对点消息的生产和消费。最后,通过浏览器访问测试接口验证消息传递的成功性。
69 0