利用rabbitMQ实现mysql与ElasticSearch的数据同步

本文介绍了如何利用rabbitMQ作为中间件,实现在mysql数据增删改时,实时同步到ElasticSearch。配置了两个消息队列分别对应数据变更和删除操作,创建主题交换机并绑定队列,生产者(数据库服务方)发送操作消息,消费者(ES服务方)监听队列并根据key调用相应服务同步数据。
摘要由CSDN通过智能技术生成

点击上方蓝字"优派编程"选择“加为星标”,第一时间关注原创干货

生产者消费者导入MQ的依赖

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-amqp</artifactId>
</dependency>

添加配置

spring: rabbitmq: host: localhost port: 5672 username: admin password: 123456 virtual-host: myHost

RabbitMQ的配置信息 两个消息队列 分别是数据增改 和 删除的队列

创建主题(topic)类型的交换机,并绑定刚刚创建的两个消息队列,并分别设置相应的key,消费者可以通过不同的key来判断该消费那一条消息队列的数据。

生产者的配置 所谓的生产者就是我们数据库的服务方,当我们对数据库的数据进行增删改的时候,我们应该像消息队列发送消息来通知ES我们进行了增删改操作,以便ES进行数据的同步。

/**
* RabbitMQ的配置
*/
@Configuration
public class RabbitMQConfig {


public static final String QUEUE_COURSE_SAVE = "queue.course.save";
public static final String QUEUE_COURSE_REMOVE = "queue.course.remove";
public static final String KEY_COURSE_SAVE = "key.course.save";
public static final String KEY_COURSE_REMOVE = "key.course.remove";
public static final String COURSE_EXCHANGE = "edu.course.exchange";


@Bean
public Queue queueCourseSave() {
return new Queue(QUEUE_COURSE_SAVE);
}


@Bean
public Queue queueCourseRemove() {
return new Queue(QUEUE_COURSE_REMOVE);
}


@Bean
public TopicExchange topicExchange() {
r
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值