AMQP[RabbitMQ]小结

news2025/1/21 17:59:23

在这里插入图片描述

消息队列:

组成:

交换器,队列,绑定

作用:异步处理,削峰,服务解耦

交换器

RabbitMQ常见的exchange(交换器)类型:

  • direct–路由键完全匹配才可以

  • fanout–广播

  • topic --主题,模糊匹配路由键

队列

messagequeue:

组成:

  • 路由键 routine-key—决定消息发给谁

  • 优先级priority–决定消息发送的优先级

  • 分发模式deliver-mode–决定消息的发送方式–持久化等

绑定

binding:

依赖

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

配置文件:

spring:
  rabbitmq:
    username: zzy
    password: 1234
    host: 172.24.232.166

注册队列:

@Configuration
public class RabbitConfig {
    @Bean
    protected Queue queue(){

        Queue queue= new Queue("zzy");
        return  queue;
    }
}

生产者发送消息

//作为信息的发布者
@SpringBootTest(classes = ApplicationRabbitMq.class)
public class RabbitTest {
    //Amqp模板类
    @Autowired
    private AmqpTemplate amqpTemplate;

    @Test
    void RabbitTest(){
        amqpTemplate.convertAndSend("zzy","hello world");
        System.out.println("success");
    }
}

消费者消费消息:

@Component  //加注解,不然无法解析
public class RabbitMqConsumer {

    @RabbitListener(queues = "zzy")//订阅的队列
    public void Listened1(String msg){

        System.out.println("取出的消息1----"+msg);
    }
    @RabbitListener(queues = "zzy")
    public void Listened2(String msg){

        System.out.println("取出的消息2----"+msg);
    }
}

默认使用direct队列,如果要使用广播队列:

import org.springframework.amqp.core.Binding;
import org.springframework.amqp.core.BindingBuilder;
import org.springframework.amqp.core.FanoutExchange;
import org.springframework.amqp.core.Queue;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class RabbitFanoutConfig {

    //准备两个队列

    @Bean
    protected Queue queue() {

        return new Queue("gavin");
    }


    @Bean
    protected Queue queue2() {

        return new Queue("zzy");
    }

//内置fanout交换器名称amq.fanout

    @Bean
    protected FanoutExchange fanoutExchange() {

        return new FanoutExchange("amq.fanout");
    }

 //将交换器和队列绑定

    @Bean
    protected Binding fanoutBinding(Queue queue, FanoutExchange fanoutExchange) {

        return BindingBuilder.bind(queue).to(fanoutExchange);
    }

    @Bean
    protected Binding fanoutBinding2(Queue queue2, FanoutExchange fanoutExchange) {

        return BindingBuilder.bind(queue2).to(fanoutExchange);
    }
}

一个交换器可以绑定多个队列;

几个重要的注解/Bean

import org.springframework.amqp.core.AmqpTemplate;
@Bean
AmqpTemplate amqpTemplate 
//此模板中有发送消息的方法

-------------------------------------
import org.springframework.amqp.core.Queue;
//注册一个队列direct
  @Bean
    protected Queue queue() {

        return new Queue("gavin");
    }

//注册一个广播交换器
 @Bean
    protected FanoutExchange fanoutExchange() {

        return new FanoutExchange("amq.fanout");
    }
//交换器绑定队列
 //将交换器和队列绑定

    @Bean
    protected Binding fanoutBinding(Queue queue, FanoutExchange fanoutExchange) {

        return BindingBuilder.bind(queue).to(fanoutExchange);
    }
//注册一个topic交换器
 @Bean
    protected TopicExchange topicExchange() {

        return new TopicExchange("amq.topic");
    }
//绑定队列
 //将交换器和队列绑定

    @Bean
    protected Binding TopicBind1(Queue queue, TopicExchange topicExchange) {

        return BindingBuilder.bind(queue).to(topicExchange).with("com.gavin.*");//匹配路由规则
    }

消费者:

 @RabbitListener(queues = "gavin")
 该方法从对列中消费消息

消息重复消费原因:

消费完毕后本该向broker发送ack,但是由于网路延迟较高过了broker等待的时间,于是broker会把消息再次投递到consumer

解决方案:

数据库—处理消息前,使用消息主键在表中带有约束的字段中insert,插入成功则消费成功,插入失败则已经消费过了,不再进行消费

Map–单机版的使用ConrrentHashMap ->putifAbsent

Redis --分布式锁

保证消息队列的消费顺序

同一个topic,同一个queue,发的时候让一个线程去发,消费的时候让一个线程去消费,如果多线程暂时无法保证消费的有序性

怎么保证消息发送到同一个queue?

RocketMQ 提供了一个MessageQueueSelector 接口,重写接口方法

RocketMQ如何保证消息不丢失

Producer端:

采用send()同步发消息,发送结果是同步感知的;

Broker端:

设置数显策略为同步刷新策略

集群部署,配置主从,高可用模式

Consumer端:

消费正常后再进行手动ACK确认

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1046333.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

vue 普通组件的 局部注册

vue 普通组件的 注册 11 Vue2_3入门到实战-配套资料\01-随堂代码素材\day03\素材\00-准备代码\小兔鲜首页静态页\src

工厂与观察者模式

工厂模式介绍 通过一个加工厂&#xff0c;在这个工厂中添加对应材料&#xff0c;我们就可以得到想要的东西&#xff0c;在程序设计中&#xff0c;这种模式就叫做工厂模式&#xff0c;工厂生成出的产品就是某个类的实例&#xff0c;也就是对象。 关于工厂模式一共有三种&#…

【C++11】左值引用右值引用,移动构造的使用

&#x1f30f;博客主页&#xff1a; 主页 &#x1f516;系列专栏&#xff1a; C ❤️感谢大家点赞&#x1f44d;收藏⭐评论✍️ &#x1f60d;期待与大家一起进步&#xff01; 文章目录 一、左值与右值二、 引用总结&#xff1a;1.左值&#xff1a;2.右值&#xff1a; 三、…

微服务调用没有返回值,无法组成对象,但是会有feign的信息

事件起因 还是那个项目&#xff0c;至少对于我来说要学习的东西其实还是挺多的。 需求 员工信息管理&#xff0c;员工简历&#xff0c;导出功能&#xff0c;需要去联查员工的各项信息&#xff0c;其中&#xff0c;涉及到微服务的之间的操作出现了问题&#xff0c;目前主要的…

时空碰撞之当Leaflet遇到Echarts

前言 在之前的博客中&#xff0c;有介绍如何进行Leaflet展示的&#xff0c;也有介绍Echarts如何进行高效图表展示的。针对一些时空类的场景&#xff0c;比如需要跟随GIS地图一起进行图表展示&#xff0c;如何在地图上集成图表插件。本文将以常用的Leaflet为例&#xff0c;重点讲…

JAVA中使用CompletableFuture进行异步编程

JAVA中使用CompletableFuture进行异步编程 1、什么是CompletableFuture CompletableFuture 是 JDK8 提供的 Future 增强类&#xff0c;CompletableFuture 异步任务执行线程池&#xff0c;默认是把异步任 务都放在 ForkJoinPool 中执行。 在这种方式中&#xff0c;主线程不会…

I/O

IO 流简介 IO 即 Input/Output&#xff0c;输入和输出。数据输入到计算机内存的过程即输入&#xff0c;反之输出到外部存储&#xff08;比如数据库&#xff0c;文件&#xff0c;远程主机&#xff09;的过程即输出。IO 流在 Java 中分为输入流和输出流&#xff0c;而根据数据的…

DAY47 多表外键联系

一、表设计之关联关系 外键&#xff1a;主键是用于表示数据的唯一性字段&#xff0c;外键是用于建立关联关系的字段&#xff0c;值通常指向另一张表的主键 一对一 什么是一对一的关系&#xff1a;有A,B两张表&#xff0c;A表中一条数据对应B表中的一条数据&#xff0c;称之为一…

Java 设计模式——抽象工厂模式

目录 1.概念2.结构3.实现4.优缺点5.使用场景6.模式扩展7.JDK源码解析——Collection.iterator方法 1.概念 &#xff08;1&#xff09;Java 设计模式——工厂方法模式中考虑的是一类产品的生产&#xff0c;如畜牧场只养动物、电视机厂只生产电视机等。这些工厂只生产同种类产品…

MATLAB m文件格式化

记录一个网上查到的目前感觉挺好用的格式化方法。 原链接&#xff1a; https://cloud.tencent.com/developer/article/2058259 压缩包&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1ZpQ9qGLY7sjcvxzjMPAitw?pwd6666 提取码&#xff1a;6666 下载压缩包&#xf…

【GDB】自定义命令

.gdbinit 文件的使用 gdb自定义命令 自定义命令格式 define <command> <code> end document <command> <help text> end示例 .gdbinit 脚本中输入如下内容 layout asm b 5define print-tyustliecho hello, world\n enddocument print-tyustliusage…

【冒烟测试前置】如何把控提测质量?

你是否碰到过开发提测速度很快&#xff0c;导致项目排队&#xff0c;结果介入测试时&#xff0c;第一条用例都跑不通的情况&#xff1f; 你是否碰到过因为开发提测质量差&#xff0c;导致反复修改&#xff0c;反复提测&#xff0c;反复重复验证的情况&#xff1f; 你是否碰到…

sql数据类型,约束以及单表查询

嘎嘎学撒 数据类型约束条件DML 数据操作语句一、插入数据INSERT二、更新数据UPDATE三、删除数据DELETE四、MySQL单表查询五、关键词 数据类型 常见的数据类型 数值类型&#xff1a; 整数类型 TINYINT SMALLINT MEDIUMINT INT BIGINT 整型可以指定是有符号的和无符号的&#xf…

如何快速做跨业务测试?

当业务任务多且人力资源不充足的情况下&#xff0c;不同业务的同学可能需要去不同的业务进行临时支援&#xff0c;可能在时间方面有长有短&#xff0c;但是如何迈出第一步是很多人需要关心的一件事。 本文以实际跨业务测试经验&#xff08;订单业务测试人员如何测试售后业务&a…

【操作】国标GB28181视频监控EasyGBS平台更新设备信息时间间隔

国标GB28181协议视频平台EasyGBS是基于GB28181协议的视频监控云服务平台&#xff0c;可支持多路设备同时接入&#xff0c;并对多平台、多终端分发出RTSP、RTMP、FLV、HLS、WebRTC等格式的视频流。平台可提供视频监控直播、云端录像、云存储、检索回放、智能告警、语音对讲、平台…

[Python进阶] Pyinstaller打包程序时为程序添加图标

5.5 Pyinstaller打包程序时为程序添加图标 5.5.1 程序图标的好处 增强可识别性&#xff1a;图标是一种视觉语言&#xff0c;能够提高应用程序的可识别性&#xff0c;使其在众多应用程序中更容易被用户找到和识别。 帮助用户理解应用程序功能&#xff1a;图标可以快速传达应用…

硬件基本功--电阻/电容/电感/二极管

一、电阻 电阻的主要参数&#xff1a;阻值、精度、封装、功率、耐压 电阻在电路中的作用&#xff1a;分压、限流、采样、偏置等等 阻值&#xff1a;103 10*1000 10KΩ 电阻流过电流&#xff0c;就会有压降&#xff0c;从而产生功率损耗 电阻封装、功率、耐压的关系&#xff1…

青云1000----华为昇腾310 注意事项

青云1000帮助文档 只是一部分&#xff0c;后续遇到的问题会补充 注意事项&#xff01;&#xff01;&#xff01;&#xff01; type-c只用于数据传输不能供电DC供电和锂电池不能同时供电&#xff0c;会烧掉风扇正负级不要插反 账户密码 HwHiAiUser 密码Mind123 TypeC USB …

接口测试——接口协议抓包分析与mock_L2

目录&#xff1a; 抓包工具charles抓包工具fiddler抓包工具证书配置app抓包实战练习接口测试实战练习 1.抓包工具charles 工具介绍 支持 SSL 代理支持流量控制支持重发网络请求&#xff0c;方便后端调试支持修改网络请求参数支持网络请求的截获并动态修改可以自动将 json 或…

七、栈与队列(stack and queue)

文章目录 一、栈与队列基础二、例题&#xff08;一&#xff09;栈1.[232. 用栈实现队列](https://leetcode.cn/problems/implement-queue-using-stacks/description/)&#xff08;1&#xff09;思路&#xff08;2&#xff09;代码&#xff08;3&#xff09;复杂度分析 2.[225. …