第三课 ActiveMQ在项目中的使用

分析:
在后台每次添加或修改文章的时候,发送一个消息,内容为新添加或修改的文章id,solr服务层接收到消息后取出文章id,根据id去数据库查询文章信息,然后更新索引库,从而达到同步效果。修改的话同时还要删除redis缓存,如果不使用ActiveMQ,同时做这许多事会导致客户端响应慢。

配置文件中:配置连接工厂生产者,目的地。

<!-- 真正可以产生Connection的ConnectionFactory,由对应的 JMS服务厂商提供 -->
    <bean id="targetConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory">
        <property name="brokerURL" value="tcp://192.168.25.128:61616" />
    </bean>
    <!-- Spring用于管理真正的ConnectionFactory的ConnectionFactory -->
    <bean id="connectionFactory"
        class="org.springframework.jms.connection.SingleConnectionFactory">
        <!-- 目标ConnectionFactory对应真实的可以产生JMS Connection的ConnectionFactory -->
        <property name="targetConnectionFactory" ref="targetConnectionFactory" />
    </bean>
    <!-- 配置生产者 -->
    <!-- Spring提供的JMS工具类,它可以进行消息发送、接收等 -->
    <bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate">
        <!-- 这个connectionFactory对应的是我们定义的Spring提供的那个ConnectionFactory对象 -->
        <property name="connectionFactory" ref="connectionFactory" />
    </bean>
    <!--这个是队列目的地,点对点的 -->
    <bean id="queueDestination" class="org.apache.activemq.command.ActiveMQQueue">
        <constructor-arg>
            <value>spring-queue</value>
        </constructor-arg>
    </bean>

    <!--这个是主题目的地,一对多的 -->
    <bean id="topicDestination" class="org.apache.activemq.command.ActiveMQTopic">
        <constructor-arg value="itemAddTopic" />
    </bean>
Controller:

  @Controller
public class HomeController {
    @Autowired
    private JmsTemplate jmsTemplate;
    //注入主题目的地(发布/订阅模式)
    @Autowired
    private Destination topicDestination;
    @RequestMapping("/")
    public ModelAndView home() throws IOException, SolrServerException {


        jmsTemplate.send(topicDestination, new MessageCreator() {

            @Override
            public Message createMessage(Session session) throws JMSException {
                TextMessage message = session.createTextMessage(99+"");
                return message;
            }
        });

     
        return null;
    }
}

接收消息,实现solr索引库文章信息与数据库文章信息同步

配置文件中:配置连接工厂,目的地,自定义消息监听器和消息监听容器

<!-- 真正可以产生Connection的ConnectionFactory,由对应的 JMS服务厂商提供 -->
    <bean id="targetConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory">
        <property name="brokerURL" value="tcp://192.168.25.128:61616" />
    </bean>
    <!-- Spring用于管理真正的ConnectionFactory的ConnectionFactory -->
    <bean id="connectionFactory"
        class="org.springframework.jms.connection.SingleConnectionFactory">
        <!-- 目标ConnectionFactory对应真实的可以产生JMS Connection的ConnectionFactory -->
        <property name="targetConnectionFactory" ref="targetConnectionFactory" />
    </bean>

    <!--这个是队列目的地,点对点的 -->
    <bean id="queueDestination" class="org.apache.activemq.command.ActiveMQQueue">
        <constructor-arg>
            <value>spring-queue</value>
        </constructor-arg>
    </bean>
    <!--这个是主题目的地,一对多的 -->
    <bean id="topicDestination" class="org.apache.activemq.command.ActiveMQTopic">
        <constructor-arg value="itemAddTopic" />
    </bean>

    <bean id="itemAddMessageListener" class="cn.e3mall.search.message.ItemAddMessageListener"></bean>
    <!-- 监听商品添加消息,同步索引库 -->
    <bean class="org.springframework.jms.listener.DefaultMessageListenerContainer">
        <property name="connectionFactory" ref="connectionFactory" />
        <property name="destination" ref="topicDestination" />
        <property name="messageListener" ref="itemAddMessageListener" />
    </bean>

自定义文章修改消息监听器

package com.neusoft.util;

import org.springframework.stereotype.Component;

import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.TextMessage;

/**
 * Created by Administrator on 2018/8/15.
 */

public class ItemAddMessageListener implements MessageListener {

    public void onMessage(Message message) {
        //从消息中取商品id
        TextMessage textMessage = (TextMessage) message;
        try {
            String text = textMessage.getText();
            Long itemId = Long.parseLong(text);
            System.out.println("onMessageonMessageonMessageonMessageonMessage"+itemId);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

}
```
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,026评论 19 139
  • 关于Mongodb的全面总结 MongoDB的内部构造《MongoDB The Definitive Guide》...
    中v中阅读 32,048评论 2 89
  • 初见时,我是明艳美丽却骄傲任性的少女,而你是朴实平凡却温文尔雅的少年;曾经你说你对我一见钟情,我却不信,甚至嗤之...
    Luceyfar阅读 386评论 0 0
  • 没有什么幸福比得上 成为创造力本身 远离对结果的期望与执着 我们是快乐的孩子 只管在春天播种自己的想象 天马行空 ...
    SharonZhou阅读 339评论 0 1
  • 在我的脑海里 想起母亲 总有这样一个身影—— 穿着一条方格短裙 白皙的皮肤 匀称的身材 纤细的腰身 这个身影 在我...
    三月的雨s阅读 351评论 0 0