首页 > 其他分享 >RabbitMQ 入门(四)SpringAMQP五种消息类型(Basic Queue)

RabbitMQ 入门(四)SpringAMQP五种消息类型(Basic Queue)

时间:2024-11-23 23:26:27浏览次数:5  
标签:queue SpringAMQP 队列 spring RabbitMQ Queue 消息 import org

  一、Spring AMQP 简介


SpringAMQP是基于RabbitMQ封装的一套模板,并且还利用SpringBoot对其实现了自动装配,使用起来非常方便。

SpringAmqp的官方地址:https://spring.io/projects/spring-amqp

SpringAMQP提供了三个功能:

- 自动声明队列、交换机及其绑定关系
- 基于注解的监听器模式,异步接收消息
- 封装了RabbitTemplate工具,用于发送消息

AMQP,即Advanced Message Queuing Protocol,是用于在应用程序之间传递业务消息的开放标准,该协议与语言和平台无关,更符合微服务中独立性的要求。

Spring AMQP 是基于AMQP协议定义的一套API规范,提供了模版来发送和接受消息。包含两部分,其中Spring-amqp是基础抽象,spring-rabbit是底层的默认实现。

二、使用Spring AMQP实现基础消息队列功能
基础消息队列模式的模型图:

 

 

基础的消息队列模型包括三个角色:

- publisher:消息发布者,将消息发送到队列queue
- queue:消息队列,负责接受并缓存消息
- consumer:订阅队列,处理队列中的消息

使用Spring AMQP实现基础消息队列功能

流程如下:
1.在父工程中引入spring-amqp的依赖
2.在publisher 服务中利用RabbitTemplate发送消息到 simple.queue 这个队列
3.在consumer服务中编写消费逻辑,绑定 simple.queue 这个队列

步骤一:在父工程中引入依赖

<!--AMQP依赖,包含RabbitMQ-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-amqp</artifactId>
</dependency>

 


步骤二:在publisher中编写测试方法,向 simple.queue发送消息

1).在publisher服务 中编写application.yml,添加mq连接信息:

spring:
  rabbitmq:
    host: 192.168.150.101 # 主机名
    port: 5672 # 端口
    virtual-host: / # 虚拟主机
    username: rbmq # 用户名
    password: 123456 # 密码

 


2).在publisher服务中编写测试类SpringAmqpTest,并利用RabbitTemplate实现消息发送:

 

import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;
 
@RunWith(SpringRunner.class)
@SpringBootTest
public class SpringAmqpTest {
 
    @Autowired
    private RabbitTemplate rabbitTemplate;
 
    @Test
    public void testSimpleQueue() {
        // 队列名称
        String queueName = "simple.queue";
        // 消息
        String message = "hello, spring amqp!";
        // 发送消息
        rabbitTemplate.convertAndSend(queueName, message);
    }
}

 

 

步骤三:在consumer服务中编写消费逻辑,绑定 simple.queue 这个队列

1.在consumer服务中编写 application.yml,添加mq连接信息;

spring:
  rabbitmq:
    host: 192.168.150.101 # 主机名
    port: 5672 # 端口
    virtual-host: / # 虚拟主机
    username: rbmq # 用户名
    password: 123456 # 密码

 

 

2.在consumer服务中新建一个类,编写消费逻辑

import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Component;
 
@Component
public class SpringRabbitListener {
 
    @RabbitListener(queues = "simple.queue")
    public void listenSimpleQueueMessage(String msg) throws InterruptedException {
        System.out.println("spring 消费者接收到消息:【" + msg + "】");
    }
}

 


步骤四:运行springboot程序,测试发送接收消息。成功

标签:queue,SpringAMQP,队列,spring,RabbitMQ,Queue,消息,import,org
From: https://www.cnblogs.com/kongsq/p/18565238

相关文章

  • RabbitMQ 入门(五)SpringAMQP五种消息类型(Work Queue)
    一、WorkQueue(工作消息队列)Workqueues,也被称为(Taskqueues),任务模型。简单来说就是让多个消费者绑定到一个队列,共同消费队列中的消息。当消息处理比较耗时的时候,可能生产消息的速度会远远大于消息的消费速度。长此以往,消息就会堆积越来越多,无法及时处理。此时就可以......
  • RabbitMQ2:介绍、安装、快速入门、数据隔离
    欢迎来到“雪碧聊技术”CSDN博客!在这里,您将踏入一个专注于Java开发技术的知识殿堂。无论您是Java编程的初学者,还是具有一定经验的开发者,相信我的博客都能为您提供宝贵的学习资源和实用技巧。作为您的技术向导,我将不断探索Java的深邃世界,分享最新的技术动态、实战经验以及项目......
  • C++ 标准模板库(STL)——queue的使用
    目录一、描述二、初始化1、包含的头文件2、变量初始化三、函数1、构造函数2、成员函数四、插入元素五、删除元素六、访问元素七、修改元素八、示例代码九、注意事项十、总结一、描述STL(StandardTemplateLibrary)是C++标准库的一部分,它提供了一系列容......
  • Spring Boot 集成 RabbitMQ 完整教程(含 Windows 安装 RabbitMQ)
    在现代分布式系统中,消息队列是一种非常重要的组件,用于解耦应用程序的各个部分、异步处理任务、提高系统的可扩展性和容错性。RabbitMQ是一种流行的消息队列中间件,支持多种消息协议,其中AMQP(AdvancedMessageQueuingProtocol)是其默认支持的协议。本文将详细介绍如何在Wi......
  • 在使用 RabbitMQ 作为消息代理时,多个 Celery 实例(或应用)可以共享同一个 RabbitMQ 实例
    在使用RabbitMQ作为消息代理时,多个Celery实例(或应用)可以共享同一个RabbitMQ实例。这样做可以简化基础设施管理,同时允许不同的Celery应用之间进行消息传递和协作。下面是如何配置多个Celery实例以使用同一个RabbitMQ实例的步骤:1.安装依赖确保你的Python环......
  • 使用RabbitMQ实现延迟消息的完整指南
    在分布式系统中,消息队列通常用于解耦服务,RabbitMQ是一个广泛使用的消息队列服务。延迟消息(也称为延时队列或TTL消息)是一种常见的场景应用,特别适合处理某些任务在一段时间后执行的需求,如订单超时处理、延时通知等。本文将以具体代码为例,展示如何使用RabbitMQ来实现延迟消息处理......
  • ActiveMQ消息模式Queue和Topic机制讲解
    Docker安装ActiveMQ镜像以及通过Java生产消费activemq示例_dockeractivemq-CSDN博客背景周末由于服务器异常宕机,导致业务系统重启后出现ActiveMQ中的数据没有被正常消费,运维认为是消息积压,便联系博主排查。最终发现并不存在消息积压,是因为采用ActiveMQTopic模式生产消费......
  • 优先级队列(priority_queue)
     priority_queue简介   优先级队列的底层结构其实就是堆,就是我们在学习二叉树的时候学习的堆。它是一种逻辑结构,底层还是vector,我们把它想象成一个堆结构。    我们在学习堆的时候,知道了它的父亲和左右孩子的关系。它如果存在孩子,则一定存在这一种关系,leftchi......
  • RabbitMQ实现高可用性
    RabbitMQ可以通过多种方式来实现高可用性,以下是一些常见的方法:集群模式原理:通过创建RabbitMQ集群来实现高可用性。在集群中,多个RabbitMQ节点相互连接并共享数据,当一个节点出现故障时,其他节点可以继续提供服务。实现方式:创建多个RabbitMQ节点,并将它们连接在一起形成集......
  • flume传输数据报错“Space for commit to queue couldn‘t be acquired. Sinks are li
        最近在写一个数据量比较大的项目时候,需要使用flume将kafka中的数据传输到HDFS上进行存储,方便后续的数仓搭建,但是flume在传输数据中却报错如下日志org.apache.flume.ChannelFullException:Spaceforcommittoqueuecouldn'tbeacquired.Sinksarelikelynot......