springBoot+rabbit消息获取和消息确认

简介: springBoot+rabbit消息获取和消息确认

1.消息获取

/*

 * 接收消息
 * 发布订阅模式
 * 1.一次性获取队列名称为fanout_queue_notify1 的所有准备好的消息,  messageCount 为总条数
 * @return
 */
@Override
public AjaxResult consumption() throws Exception {
    JSONArray jsonArray = new JSONArray();
    //获取队列中的消息个数
    AMQP.Queue.DeclareOk declareOk = rabbitTemplate.execute(new ChannelCallback<AMQP.Queue.DeclareOk>() {
        public AMQP.Queue.DeclareOk doInRabbit(Channel channel) throws Exception {
            return channel.queueDeclarePassive("fanout_queue_notify1");
        }
    });
    int messageCount = declareOk.getMessageCount();
    System.out.printf("MQ的queues中对应消息总条数为====》" + messageCount);

    rabbitTemplate.execute(
            channel -> {
                long deliveryTag = 0;//待确认的消息总数
                int num = 0;
                //每次读取一条消息
                while (num < messageCount) {
                    StringBuilder stringBuilder = new StringBuilder();
                    GetResponse response = channel.basicGet("fanout_queue_notify1", false);
                    byte[] bodyBytes = response.getBody();
                    String json = new String(bodyBytes);
                    log.info("mq接收到的消息为1=====》" + response);
                    deliveryTag = response.getEnvelope().getDeliveryTag();
                    stringBuilder.append(json);
                    num = num + 1;

                    JSONObject jsonObject = JSON.parseObject(stringBuilder.toString());
                    jsonArray.add(jsonObject);
                }
                return null;
            });

    if (jsonArray.size() < 1) {
        throw new CustomException("消息队列里面没有 已经准备好的消息!");
    }
    System.out.printf("************************" + jsonArray);
    return AjaxResult.success(jsonArray);
}

image.png

  1. 2.消息确认
    /*
    • 消费者 确认消息
    • @return
    • @throws Exception
      */
      @Override
      public AjaxResult consumption1(String messageId) {
      try {
       rabbitTemplate.execute(
               channel -> {
                   channel.basicAck(1, true);
                   return null;
               }
       );
      
      }catch (Exception e){
      // channel.basicReject(deliveryTag, false);
       throw new CustomException("消息确认失败,请联系管理员!");
      
      }
      return AjaxResult.success();
      }
相关文章
|
7月前
|
消息中间件 SQL Java
spring boot Rabbit高级教程(三)
spring boot Rabbit高级教程
99 0
|
7月前
|
消息中间件 Java 测试技术
spring boot Rabbit高级教程(二)
spring boot Rabbit高级教程
51 0
|
7月前
|
消息中间件 存储 Java
spring boot Rabbit高级教程(一)
spring boot Rabbit高级教程
133 0
|
消息中间件 Java
springboot之rabbit - producer的confirm和consumer的ack模式
本篇和大家分享的是关于rabbit的生产和消费方的一些实用的操作;正如文章标题,主要内容如producer的confirm和consumer的ack,这两者使用的模式都是用来保证数据完整性,防止数据丢失。
8797 0
|
2月前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 实现动态路由和菜单功能,快速搭建前后端分离的应用框架
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 实现动态路由和菜单功能,快速搭建前后端分离的应用框架。首先,确保开发环境已安装必要的工具,然后创建并配置 Spring Boot 项目,包括添加依赖和配置 Spring Security。接着,创建后端 API 和前端项目,配置动态路由和菜单。最后,运行项目并分享实践心得,包括版本兼容性、安全性、性能调优等方面。
190 1
|
1月前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用。
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用。首先,创建并配置 Spring Boot 项目,实现后端 API;然后,使用 Ant Design Pro Vue 创建前端项目,配置动态路由和菜单。通过具体案例,展示了如何快速搭建高效、易维护的项目框架。
119 62
|
14天前
|
存储 JavaScript 前端开发
基于 SpringBoot 和 Vue 开发校园点餐订餐外卖跑腿Java源码
一个非常实用的校园外卖系统,基于 SpringBoot 和 Vue 的开发。这一系统源于黑马的外卖案例项目 经过站长的进一步改进和优化,提供了更丰富的功能和更高的可用性。 这个项目的架构设计非常有趣。虽然它采用了SpringBoot和Vue的组合,但并不是一个完全分离的项目。 前端视图通过JS的方式引入了Vue和Element UI,既能利用Vue的快速开发优势,
79 13
|
22天前
|
JavaScript 安全 Java
java版药品不良反应智能监测系统源码,采用SpringBoot、Vue、MySQL技术开发
基于B/S架构,采用Java、SpringBoot、Vue、MySQL等技术自主研发的ADR智能监测系统,适用于三甲医院,支持二次开发。该系统能自动监测全院患者药物不良反应,通过移动端和PC端实时反馈,提升用药安全。系统涵盖规则管理、监测报告、系统管理三大模块,确保精准、高效地处理ADR事件。
|
1月前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个前后端分离的应用框架,实现动态路由和菜单功能
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个前后端分离的应用框架,实现动态路由和菜单功能。首先,确保开发环境已安装必要的工具,然后创建并配置 Spring Boot 项目,包括添加依赖和配置 Spring Security。接着,创建后端 API 和前端项目,配置动态路由和菜单。最后,运行项目并分享实践心得,帮助开发者提高开发效率和应用的可维护性。
102 2
|
1月前
|
JavaScript Java 项目管理
Java毕设学习 基于SpringBoot + Vue 的医院管理系统 持续给大家寻找Java毕设学习项目(附源码)
基于SpringBoot + Vue的医院管理系统,涵盖医院、患者、挂号、药物、检查、病床、排班管理和数据分析等功能。开发工具为IDEA和HBuilder X,环境需配置jdk8、Node.js14、MySQL8。文末提供源码下载链接。