zoukankan      html  css  js  c++  java
  • 五、Sping 中实现简单实现activeMQ

    一、在spring的pom.xml引入依赖

    <!-- 消息队列 -->
    <dependency>
        <groupId>org.apache.activemq</groupId>
        <artifactId>activemq-core</artifactId>
        <version>5.7.0</version>
        <exclusions>
            <exclusion>
                <groupId>org.springframework</groupId>
                <artifactId>spring-context</artifactId>
            </exclusion>
        </exclusions>
    </dependency>
    <!-- 单元测试 -->
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>${junit.version}</version>
        <scope>test</scope>
    </dependency>
    <!-- spring -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-beans</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-jdbc</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-aspects</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-jms</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context-support</artifactId>
        <version>${spring.version}</version>
    </dependency>
    

      

    二、配置消息的公共配置文件

    <?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"
           xsi:schemaLocation="http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans.xsd
           http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">
        <!--开启注解配置-->
        <context:annotation-config/>
        <!--ActiveMQ为我们提供的connectionFactory-->
        <bean id="targetConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory">
            <property name="brokerURL" value="tcp://127.0.0.1:61616"/>
        </bean>
        <!--spring jms为我们提供的连接池-->
        <bean id="connectionFactory" class="org.springframework.jms.connection.SingleConnectionFactory">
            <property name="targetConnectionFactory" ref="targetConnectionFactory"/>
        </bean>
        <!--一个队列目的地,点对点-->
        <bean id="queueDestination" class="org.apache.activemq.command.ActiveMQQueue">
            <constructor-arg value="queue"/><!--该构造参数为:目的地队列名称-->
        </bean>
        <!--一个主题模式目的地,发布订阅-->
        <bean id="topticDestination" class="org.apache.activemq.command.ActiveMQTopic">
            <constructor-arg value="topic"/>
        </bean>
    </beans>

    三、编写生产者的code和配置文件

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
           xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd ">
        <!--导入公共配置-->
        <import resource="common.xml"/>
    
        <!--配置spring 提供的JmsTemplate用于发送和接收消息的模板类 -->
        <bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate">
            <constructor-arg name="connectionFactory" ref="connectionFactory"/>
        </bean>
    
        <bean class="com.du.jms.producer.ProducerServiceImpl"/>
    </beans>

    1.创建生产者service接口

    package com.du.jms.producer;
    
    public interface ProducerService {
         void sendMessage(String message);
    }
    

    2.实现生产者service接口

    package com.du.jms.producer;
    
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.jms.core.JmsTemplate;
    import org.springframework.jms.core.MessageCreator;
    
    import javax.annotation.Resource;
    import javax.jms.*;
    
    public class ProducerServiceImpl implements ProducerService {
        @Autowired
        private JmsTemplate jmsTemplate;
        //使用资源的方式注解,用来区分不同的目的地
        @Resource(name = "topticDestination")
        private Destination destination;
        public void sendMessage(final String message) {
            //使用JmsTemplate发送消息
            jmsTemplate.send(destination, new MessageCreator() {
                //创建一个消息
                public Message createMessage(Session session) throws JMSException {
                    TextMessage textMessage = session.createTextMessage(message);
                    return textMessage;
                }
            });
            System.out.println("发送消息"+message);
        }
    }

    3.调用生产者发送消息

    package com.du.jms.producer;
    
    import org.springframework.context.ApplicationContext;
    import org.springframework.context.support.ClassPathXmlApplicationContext;
    
    public class AppProducer {
        public static void main(String[] args) {
            ClassPathXmlApplicationContext context = new  ClassPathXmlApplicationContext("producer.xml");
            ProducerService service = context.getBean(ProducerService.class);
            for (int i=0;i<100;i++){
                service.sendMessage("test"+i);
            }
            context.close();//清除spring连接
        }
    }
    

    四、编写消费者的code和配置文件

    1.编写配置文件

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
           xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
        <!--导入公共配置-->
        <import resource="common.xml"/>
        <!--配置消息监听器-->
        <bean id="consumerMessageListenter" class="com.du.jms.consumer.ConsumerMessageListenter"/>
    
        <!--spring提供的监听容器 确定消息目的地和消息监听者,管理容器自动连接连接工厂-->
        <bean id="jmsContainer" class="org.springframework.jms.listener.DefaultMessageListenerContainer">
            <property name="connectionFactory" ref="connectionFactory"/>
            <property name="destination" ref="topticDestination"/>
            <property name="messageListener" ref="consumerMessageListenter"/>
        </bean>
    </beans>
    

     

    2.实现消息监听

    package com.du.jms.consumer;
    
    import javax.jms.JMSException;
    import javax.jms.Message;
    import javax.jms.MessageListener;
    import javax.jms.TextMessage;
    
    public class ConsumerMessageListenter implements MessageListener{
        public void onMessage(Message message) {//接收到消息信息后的操作
            TextMessage textMessage = (TextMessage) message;
            try {
                System.out.println("接收消息"+textMessage.getText());
            } catch (JMSException e) {
                e.printStackTrace();
            }
        }
    }
    

      

    3.加载配置文件接收消息

    package com.du.jms.consumer;
    
    import org.springframework.context.ApplicationContext;
    import org.springframework.context.support.ClassPathXmlApplicationContext;
    
    public class AppConsumer {
        public static void main(String[] args) {
            ApplicationContext context = new ClassPathXmlApplicationContext("consumer.xml");
        }
    }
    

      

    五、启动生产者和消费者的运行程序

     

  • 相关阅读:
    基础编程练习题第一波
    TYVJ 1541 八数码
    NOIP 2014 寻找道路
    NOIP2014 解方程
    POJ 3213 矩阵乘法(优化)
    POJ 1523 Tarjan求割点
    POJ 3237 树链剖分+线段树
    SPOJ 375 树链剖分
    NOIP 2012 T2 国王游戏 (贪心+高精)
    POJ 1364 差分约束
  • 原文地址:https://www.cnblogs.com/404code/p/10564178.html
Copyright © 2011-2022 走看看