目的:为了将elasticsearch做成单独的服务,那么我们必须解耦,也就是业务逻辑和搜索模块是没有关系的,并且是异步的。那么项目之间通信,使用的选择有限,消息中间件是一个不错的选择。

消息中间件常用的:ActiveMQ,RabbitMQ,RocketMQ,Kafka等。由于activeMQ是使用java开发的,并且有比较完整的文档,在很多公司都有较多的应用,最重要的,产品比较成熟。所以选择了activeMQ作为中间件。由于这个项目是探索项目,所以只是一个单机版本的中间件,并且没有对消息进行持久化,也没有判断消息的重复消费和丢失等,完全是最简单的应用。

至于复杂的东西,以后会慢慢更新。

正文

1. windows下安装并启动activeMQ。

网址:这里下载最新版本的activeMQ这里下载任意版本的activeMQ

下载完之后如下:

然后双击 bin/win64/activemq.bat  (根据自己系统启动)

启动完成之后如下:访问localhost:8161 ,然后点击 manager ActiveMQ broker  会要求输入账号密码,账号密码分别为admin,admin。(账号是在目录下 conf-->users.properties配置文件中)

第三个页面表示你已经等了成功了,在Queues和Topics里面可以看到接收到的发布,订阅消息。

2. application.properities文件配置activeMQ的参数。

application.properties配置文件如下:

spring.activemq.broker-url=tcp://localhost:61616    //tcp连接的网址和端口,这里端口是61616,不是8161
spring.activemq.close-timeout=15s
spring.activemq.user=admin
spring.activemq.password=admin
spring.activemq.pool.enabled=true
spring.activemq.pool.max-connections=10

3. 配置ActiveMQ的配置类

import org.apache.activemq.command.ActiveMQQueue;
import org.apache.activemq.command.ActiveMQTopic;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.jms.config.DefaultJmsListenerContainerFactory;
import org.springframework.jms.config.JmsListenerContainerFactory; import javax.jms.ConnectionFactory;
import javax.jms.Queue;
import javax.jms.Topic; /**
* @author: cc
* @Date: 2018/8/29 11:22
* @Description:
*/
@Configuration
public class JmsConfig { public final static String TOPIC_CREATE = "es.topic.create";
public final static String QUEUE_CREATE = "es.queue.create";
public final static String TOPIC_DELETE = "es.topic.delete";
public final static String QUEUE_DELETE = "es.queue.delete";
public final static String TOPIC_UPDATE = "es.topic.update";
public final static String QUEUE_UPDATE = "es.queue.update"; @Bean("esQueueCreate")
public Queue esQueueCreate() {
return new ActiveMQQueue(QUEUE_CREATE);
}
@Bean("esQueueDelete")
public Queue esQueueDelete() {
return new ActiveMQQueue(QUEUE_DELETE);
}
@Bean("esQueueUpdate")
public Queue esQueueUpdate() {
return new ActiveMQQueue(QUEUE_UPDATE);
} @Bean("esTopicCreate")
public Topic esTopicCreate() {
return new ActiveMQTopic(TOPIC_CREATE);
}
@Bean("esTopicDelete")
public Topic esTopicDelete() {
return new ActiveMQTopic(TOPIC_DELETE);
}
@Bean("esTopicUpdate")
public Topic esTopicUpdate() {
return new ActiveMQTopic(TOPIC_UPDATE);
}
/**
* topic模式的ListenerContainer
* @param activeMQConnectionFactory
* @return
*/
@Bean
public JmsListenerContainerFactory<?> jmsListenerContainerTopic(ConnectionFactory activeMQConnectionFactory) {
DefaultJmsListenerContainerFactory bean = new DefaultJmsListenerContainerFactory();
bean.setPubSubDomain(true);
bean.setConnectionFactory(activeMQConnectionFactory);
return bean;
} /**
* queue模式的ListenerContainer
* @param activeMQConnectionFactory
* @return
*/
@Bean
public JmsListenerContainerFactory<?> jmsListenerContainerQueue(ConnectionFactory activeMQConnectionFactory) {
DefaultJmsListenerContainerFactory bean = new DefaultJmsListenerContainerFactory();
bean.setConnectionFactory(activeMQConnectionFactory);
return bean;
}
}

解释:

这里分别定义了queue 和topic 的增加,删除,修改的消息,分别用来接收调用服务的修改,添加,删除数据的对应的操作(如果使用一个,那么就需要对数据进行判断到底是执行的什么操作。)

后来定义了两个异步的消息监听器,本质是一样的,一个监听queue,一个监听topic

4. 创建消息生成类,消息消费类

消息生成类:发送消息到activeMQ的类

import org.springframework.jms.core.JmsTemplate;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
import javax.jms.Destination; /**
* @author: cc
* @Date: 2018/8/29 11:04
* @Description:
*/ @Service
public class Producer {
@Resource
private JmsTemplate jmsTemplate; public void sendMessage(Destination destination, String message) {
this.jmsTemplate.convertAndSend(destination,message);
} }

消息消费类:只需要在需要监听的方法上加上注解:(topic或者queue)

@JmsListener(destination = JmsConfig.TOPIC,containerFactory = "jmsListenerContainerTopic")
@JmsListener(destination = JmsConfig.QUEUE,containerFactory = "jmsListenerContainerQueue")

即可完成消息的监听,你可以在你的方法上直接接受String类型的消息进行解析。

如下:

public class Consumer {
private Logger logger = LoggerFactory.getLogger(this.getClass()); @JmsListener(destination = JmsConfig.TOPIC_CREATE,containerFactory = "jmsListenerContainerTopic")
public void onTopicMessage(String msg) {
logger.info("接收到topic消息:{}",msg);
} @JmsListener(destination = JmsConfig.QUEUE_CREATE,containerFactory = "jmsListenerContainerQueue")
public void onQueueMessage(String msg) {
logger.info("接收到queue消息:{}",msg);
}
}

5. 完成

到这里已经可以发送消息和接受消息了,但是有很多问题的,比如消息丢失,重复消费等等问题,以后在解决。目前已经可以进行项目通信了。

ElasticSearch(九):springboot项目集成消息中间件activeMQ的更多相关文章

  1. SpringBoot项目集成Hystrix

    Hystrix Hystrix是由Netflix开源的一个服务隔离组件,通过服务隔离来避免由于依赖延迟.异常,引起资源耗尽导致系统不可用的解决方案. 1.什么是服务熔断   服务熔断就是对该服务的调用 ...

  2. SpringBoot项目集成PageHelper使用

    SpringBoot项目集成PageHelper使用 一.开始 ​ 地址:https://github.com/pagehelper/Mybatis-PageHelper ​ 在spring boot ...

  3. 七、SpringBoot项目集成JSP以及项目不同启动方式及访问路径配置

    1.创建JSP目录 在src/main目录下创建目录webapp/WEB-INF/jsp用于存放jsp页面,如下图: 然后再改文件夹下面我们创建JSP文件: 大家在使用IDEA 的new菜单创建JSP ...

  4. springboot项目集成activity

    1.按照上一篇博客,新建好springboot项目后,在项目pom.xml文件中添加activity依赖 <dependency> <groupId>org.activiti& ...

  5. Springboot项目集成JPush极光推送(Java SDK)

    1.由于项目的需求,需要在Android APP上实现消息推送功能,所以引用了极光推送(官网:https://www.jiguang.cn/, 文档:http://docs.jiguang.cn/) ...

  6. 使用IDEA快速搭建基于Maven的SpringBoot项目(集成使用Redis)

    迫于好久没写博客心慌慌,随便写个简单版的笔记便于查阅. 新建项目 新建项目 然后起名 继续next netx finish. 首先附上demo的项目结构图 配置pom.xml <?xml ver ...

  7. 「Elasticsearch」SpringBoot快速集成ES

    Elastic Search 的底层是开源库 Lucene.但是Lucene的使用门槛比较高,必须自己写代码去调用它的接口.而Elastic Search的出现正是为了解决了这个问题,它是 Lucen ...

  8. SpringBoot项目集成socketIo实现实时推送

    netty-socketio maven依赖 <dependency> <groupId>com.corundumstudio.socketio</groupId> ...

  9. SpringBoot项目集成cas单点登录

    添加依赖 添加cas client依赖 <dependency> <groupId>net.unicon.cas</groupId> <artifactId& ...

随机推荐

  1. 【Robot Framework 项目实战 01】使用 RequestsLibrary 进行接口测试

    写在前面 本文我们一起来学习如何使用Robot Framework 的RequestsLibrary库,涉及POST.GET接口测试,RF用例分层封装设计等内容. 接口 接口测试是我们最常见的测试类型 ...

  2. Anagram 由颠倒字母顺序而构成的字

    2018-07-15 19:23:08 Valid Anagram 问题描述: 问题描述: 可以使用map来记录各个字符出现的个数,在O(n)的时间复杂度内完成,当然也可以使用排序算法在O(nlogn ...

  3. R & ggplot2 & Excel绘图(直方图/经验分布图/QQ图/茎叶图/箱线图)实例

    持续更新~ 散点图 条形图 文氏图 饼图 盒型图 频率直方图 热图 PCA图 3D图 火山图 分面图 分面制作小多组图 地图 练习数据: year count china Ame jap '12 2. ...

  4. MSSQL 一坑 SQL Management Studio 管理工具的快捷方式被删掉了

    如果确定已经安装的情况下,到这里去找下吧(我这里用的是sql 2008) C:\Program Files\Microsoft SQL Server\100\Tools\Binn\VSShell\Co ...

  5. Anton and School - 2 CodeForces - 785D (组合计数,括号匹配)

    大意: 给定括号字符串, 求多少个子序列是RSGS. RSGS定义如下: It is not empty (that is n ≠ 0). The length of the sequence is ...

  6. Vscode设置个人爱好

    Vscode设置个人爱好   插件列表 abusaidm.html-snippets-0.1.0 adamwalzer.string-converter-0.0.9 AESSoft.aessoft-c ...

  7. laravel日志:

    laravel日志写入方法之一: Log::info('Showing user profile for user: 147258369');把日志写入到某个方法中之后,执行方法之后,日志存储起来. ...

  8. learning uboot part command

    => part --helppart - disk partition related commands Usage:part uuid <interface> <dev> ...

  9. c++理解析构函数

    析构函数有2种方式调用,一个是主动调用delete,另一个是根据RAII的规则,在对象的生命周期结束时自动析构.第一点没什么好说的,就简单讲下第二点. 对象的生命周期不等于是程序的生命周期,一般我们所 ...

  10. 读书笔记 C# Lookup<TKey,TElement>和ToLookup方法的浅析

    Lookup<TKey,TElement>类型对象和分组是一样的,就好比使用Linq的group关键字后所查询出来的结果,使用foreach的时候,都可以用IGrouping<TKe ...