下载安装Erlang和RabbitMQ

Erlang和RabbitMQ:https://www.cnblogs.com/theRhyme/p/10069611.html

AMQP协议详解与RABBITMQ,MQ消息队列的应用场景,如何避免消息丢失

https://www.cnblogs.com/theRhyme/p/9578675.html

项目创建和依赖

推荐SpringCloud项目在线创建:https://start.spring.io/

不用上面这个也行,下面有代码和依赖;

gradle的依赖,和maven差不多:

buildscript {
ext {
springBootVersion = '2.1.1.RELEASE'
}
repositories {
mavenCentral()
}
dependencies {
classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
}
} apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'
apply plugin: 'io.spring.dependency-management' group = 'xy.study'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8 repositories {
mavenCentral()
} dependencies {
implementation('org.springframework.boot:spring-boot-starter-amqp')
implementation('org.projectlombok:lombok:1.16.+')
runtimeOnly('org.springframework.boot:spring-boot-devtools')
testImplementation('org.springframework.boot:spring-boot-starter-test')
}

代码

配置文件application.properties

spring.application.name=spring-boot-rabbitmq

spring.rabbitmq.host=localhost
spring.rabbitmq.port=5672
spring.rabbitmq.username=guest
spring.rabbitmq.password=guest server.port = 5678

RabbitMQ配置文件类(注释的代码可以直接删掉):

import org.springframework.amqp.core.Binding;
import org.springframework.amqp.core.BindingBuilder;
import org.springframework.amqp.core.Queue;
import org.springframework.amqp.core.TopicExchange;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration; /**
* topic 是RabbitMQ中最灵活的一种方式,可以根据routing_key自由的绑定不同的队列
* 首先对topic规则配置
*/
//@Configuration
public class TopicRabbitConfig { final public static String QUEUE_NAME = "queue.name";
final public static String TEST_TOPIC_ROUTINGKEY = "test.topic.routingKey";
final public static String TEST_EXCHANGE_HAHA = "test.exchange.haha"; /**
* 设置交换器的名称
* @return
*//*
@Bean
TopicExchange exchange() {
return new TopicExchange(TopicRabbitConfig.TEST_EXCHANGE_HAHA);
} *//**
* 队列名称
* @return
*//*
@Bean
public Queue queueMessage() {
return new Queue(TopicRabbitConfig.QUEUE_NAME);
} *//**
* 将指定routing key的名称绑定交换器的队列
* @param queueMessage
* @param exchange
* @return
*//*
@Bean
Binding bindingExchangeMessage(Queue queueMessage, TopicExchange exchange) {
return BindingBuilder.bind(queueMessage).to(exchange).with(TopicRabbitConfig.TEST_TOPIC_ROUTINGKEY);
}*/ /**
* 匹配以topic开头的路由键routing key
* 交换机绑定多个队列
*/ /*@Bean
Binding bindingExchangeMessages(Queue queueMessages, TopicExchange exchange) {
return BindingBuilder.bind(queueMessages).to(exchange).with("topic.#");
}*/
}

生产者,这里根据Exchange和Routing Key,直接发送一个字符串:

import lombok.extern.slf4j.Slf4j;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import xy.study.rabbitmq.conf.TopicRabbitConfig; @Component
@Slf4j
public class HelloSender { @Autowired
private RabbitTemplate rabbitTemplate; /**
* 通过exchange和routingKey的方式
* rabbitTemplate.convertAndSend(String exchange, String routingKey, Object object)
* @param i
*/
public void send(int i) {
String context = "hello " + i;
log.info("Sender : {}", context);
this.rabbitTemplate.convertAndSend(TopicRabbitConfig.TEST_EXCHANGE_HAHA,TopicRabbitConfig.TEST_TOPIC_ROUTINGKEY, context);
}
}

消费者,绑定对应的Exchange,Queue和Routing Key,直接打印获取的信息:

import lombok.extern.slf4j.Slf4j;
import org.springframework.amqp.core.ExchangeTypes;
import org.springframework.amqp.rabbit.annotation.Exchange;
import org.springframework.amqp.rabbit.annotation.Queue;
import org.springframework.amqp.rabbit.annotation.QueueBinding;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.messaging.handler.annotation.Payload;
import org.springframework.stereotype.Component;
import xy.study.rabbitmq.conf.TopicRabbitConfig; @Component
@Slf4j
public class HelloReceiver {
@RabbitListener(bindings = @QueueBinding(
value = @Queue(value = TopicRabbitConfig.QUEUE_NAME, durable = "true"),
exchange = @Exchange(value = TopicRabbitConfig.TEST_EXCHANGE_HAHA, type = ExchangeTypes.TOPIC),
key = TopicRabbitConfig.TEST_TOPIC_ROUTINGKEY)
)
public void onOrgDeleted(@Payload String msg) {
log.info("HelloReceiver msg : {}",msg);
}
}

测试类,调用生产者发送信息的函数send,消费者会监听消费:

import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;
import xy.study.rabbitmq.producer.HelloSender; @RunWith(SpringRunner.class)
@SpringBootTest
public class RabbitmqApplicationTests { @Autowired
private HelloSender sender; @Test
public void testSend() {
sender.send(666);
} }

如图,控制台日志,能生成消息,并且能被对应的消费者消费。

topic exchange 通配路由中多个消费者的情况

修改消费者的代码如下:

import lombok.extern.slf4j.Slf4j;
import org.springframework.amqp.core.ExchangeTypes;
import org.springframework.amqp.rabbit.annotation.Exchange;
import org.springframework.amqp.rabbit.annotation.Queue;
import org.springframework.amqp.rabbit.annotation.QueueBinding;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.messaging.handler.annotation.Payload;
import org.springframework.stereotype.Component;
import xy.study.rabbitmq.conf.TopicRabbitConfig; @Component
@Slf4j
public class HelloReceiver { /**
* 下面四个消费者,exchange和RoutingKey都相同,最后两个消费者队列名都相同
* @param msg
*/
@RabbitListener(bindings = @QueueBinding(
value = @Queue(value = TopicRabbitConfig.QUEUE_NAME, durable = "true"),
exchange = @Exchange(value = TopicRabbitConfig.TEST_EXCHANGE_HAHA, type = ExchangeTypes.TOPIC),
key = TopicRabbitConfig.TEST_TOPIC_ROUTINGKEY)
)
public void queueName(@Payload String msg) {
log.info("{}-----HelloReceiver msg : {}",TopicRabbitConfig.QUEUE_NAME,msg);
} @RabbitListener(bindings = @QueueBinding(
value = @Queue(value = TopicRabbitConfig.QUEUE_NAME+".test", durable = "true"),
exchange = @Exchange(value = TopicRabbitConfig.TEST_EXCHANGE_HAHA, type = ExchangeTypes.TOPIC),
key = TopicRabbitConfig.TEST_TOPIC_ROUTINGKEY)
)
public void queueNameTest(@Payload String msg) {
log.info("{}-----HelloReceiver msg : {}",TopicRabbitConfig.QUEUE_NAME+".test",msg);
} /**
* 这里我的消费者队列名"123445",是乱写的,也能够接受
* @param msg
*/
@RabbitListener(bindings = @QueueBinding(
value = @Queue(value = 123445+"", durable = "true"),
exchange = @Exchange(value = TopicRabbitConfig.TEST_EXCHANGE_HAHA, type = ExchangeTypes.TOPIC),
key = TopicRabbitConfig.TEST_TOPIC_ROUTINGKEY)
)
public void queueNameNumber(@Payload String msg) {
log.info("{}-----HelloReceiver msg : {}",123445+""+".test",msg);
} /**
* 由于这个和上面的Exchange、RoutingKey、queue完全相同,所以这两个消费者,一条消息,只有一个能消费(随机)
* @param msg
*/
@RabbitListener(bindings = @QueueBinding(
value = @Queue(value = 123445+"", durable = "true"),
exchange = @Exchange(value = TopicRabbitConfig.TEST_EXCHANGE_HAHA, type = ExchangeTypes.TOPIC),
key = TopicRabbitConfig.TEST_TOPIC_ROUTINGKEY)
)
public void queueNameNumberSame(@Payload String msg) {
log.info("same+{}-----HelloReceiver msg : {}",123445+""+".test",msg);
}
}

再次执行测试,测试结果如下:

上面四个消费者代码,Exchange和RoutingKey都相同,最后两个消费者队列名都相同。

根据结果可知,当Exchange和RoutingKey相同、queue不同时,所有消费者都能消费同样的信息;

当Exchange和RoutingKey、queue都相同时(最后两个消费者),消费者中只有一个能消费信息,其他消费者都不能消费该信息。

SpringBoot整合RabbitMQ,实现消息发送和消费以及多个消费者的情况的更多相关文章

  1. SpringBoot 整合 RabbitMQ 实现消息可靠传输

    消息的可靠传输是面试必问的问题之一,保证消息的可靠传输主要在生产端开启 comfirm 模式,RabbitMQ 开启持久化,消费端关闭自动 ack 模式. 环境配置 SpringBoot 整合 Rab ...

  2. springboot整合rabbitmq,支持消息确认机制

    安装 推荐一篇博客https://blog.csdn.net/zhuzhezhuzhe1/article/details/80464291 项目结构 POM.XML <?xml version= ...

  3. springboot整合rabbitMq实现消息延时发送

    实现思路:利用mq的ttl设置消息失效时间 当达到设置时间后通过交换机到达死信队列中,消费者端绑定读取死信队列中信息来达到延时发送消息的功能. demo 如下: (1)在pom.xml 中引入rabb ...

  4. SpringBoot整合Rabbitmq设置消息请求头

    String str = "{\"origin\":\"BBC\",\"origin_coupon_id\":51,\" ...

  5. SpringBoot系列八:SpringBoot整合消息服务(SpringBoot 整合 ActiveMQ、SpringBoot 整合 RabbitMQ、SpringBoot 整合 Kafka)

    声明:本文来源于MLDN培训视频的课堂笔记,写在这里只是为了方便查阅. 1.概念:SpringBoot 整合消息服务 2.具体内容 对于异步消息组件在实际的应用之中会有两类: · JMS:代表作就是 ...

  6. springboot整合rabbitmq实现生产者消息确认、死信交换器、未路由到队列的消息

    在上篇文章  springboot 整合 rabbitmq 中,我们实现了springboot 和rabbitmq的简单整合,这篇文章主要是对上篇文章功能的增强,主要完成如下功能. 需求: 生产者在启 ...

  7. springboot学习笔记-6 springboot整合RabbitMQ

    一 RabbitMQ的介绍 RabbitMQ是消息中间件的一种,消息中间件即分布式系统中完成消息的发送和接收的基础软件.这些软件有很多,包括ActiveMQ(apache公司的),RocketMQ(阿 ...

  8. 一篇学习完rabbitmq基础知识,springboot整合rabbitmq

    一   rabbitmq 介绍 MQ全称为Message Queue,即消息队列, RabbitMQ是由erlang语言开发,基于AMQP(Advanced MessageQueue 高级消息队列协议 ...

  9. 【MQ中间件】RabbitMQ -- SpringBoot整合RabbitMQ(3)

    1.前言说明 前面一篇博客中提到了使用原生java代码进行测试RabbitMQ实现多种交换机类型的队列场景.但是在项目中我们一般使用SpringBoot项目,而且RabbitMQ天生对于Spring的 ...

随机推荐

  1. Ramdisk虚拟内存盘,Swap分区

    虚拟内存盘是通过软件将一部分内存(RAM)模拟为硬盘来使用的一种技术.相对于直接的硬盘文件访问来说,这种技术可以极大的提高在其上进行的文件访问的速度.但是RAM的易失性也意味着当关闭电源后这部分数据将 ...

  2. bzoj2555 substring(LCT 后缀自动机)

    /* 动态求right集合的大小 LCT维护parent树即可 注意 由于树是有向的不会换根并且每次操作单一, 于是不需要维护子树和(写起来很麻烦) 直接打标记修改即可 */ #include< ...

  3. retry之python重试机制

    安装 pip install retry Retry装饰器 retry(exceptions=Exception, tries=-1, delay=0, max_delay=None, backoff ...

  4. PHP的几种缓存方式

    1.文件缓存: 2.Memcached;  是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的 ...

  5. Eclipse中JSP生成的class文件去了哪里?

    转自:http://www.cnblogs.com/xing901022/p/4352999.html 首先应该了解的是Tomcat在Eclipse的映射关系,参考前一篇博文所述:Tomcat的服务器 ...

  6. 1.Hadoop简单理解与总结。

    1.什么是Hadoop? Hadoop是一种分布式数据和计算的框架.它很擅长存储大量的半结构化的数据集.数据可以随机存放,所以一个磁盘的失败并不会带来数据丢失.Hadoop也非常擅长分布式计算——快速 ...

  7. 22.Windows及linux下gerapy使用

    Windows安装 gerapy1.pip install gerapy2.gerapy init 3.cd gerapy(切换目录到gerapy文件夹)4.gerapy migrate5.gerap ...

  8. 3. java.lang.UnsupportedClassVersionError: javax/annotation/ManagedBean : Unsupported major.minor version 51.0

    问题描述:

  9. kubernetes之deployment滚动升级

    参考:https://blog.51cto.com/wutengfei/2116663 创建和管理多个Pod--Deployment Deployment 为 Pod 和 ReplicaSet 提供了 ...

  10. <基础> PHP 进阶之 流程控制(Process)

    do-while $sum = 0; $i = 10; do{ $sum += $i; $i--; }while($i > 0); //当这里的值为 false 时跳出循环 echo $sum; ...