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();
      }
相关文章
|
5月前
|
消息中间件 SQL Java
spring boot Rabbit高级教程(三)
spring boot Rabbit高级教程
90 0
|
5月前
|
消息中间件 Java 测试技术
spring boot Rabbit高级教程(二)
spring boot Rabbit高级教程
43 0
|
5月前
|
消息中间件 存储 Java
spring boot Rabbit高级教程(一)
spring boot Rabbit高级教程
89 0
|
消息中间件 Java
springboot之rabbit - producer的confirm和consumer的ack模式
本篇和大家分享的是关于rabbit的生产和消费方的一些实用的操作;正如文章标题,主要内容如producer的confirm和consumer的ack,这两者使用的模式都是用来保证数据完整性,防止数据丢失。
8786 0
|
10天前
|
前端开发 JavaScript Java
基于Java+Springboot+Vue开发的服装商城管理系统
基于Java+Springboot+Vue开发的服装商城管理系统(前后端分离),这是一项为大学生课程设计作业而开发的项目。该系统旨在帮助大学生学习并掌握Java编程技能,同时锻炼他们的项目设计与开发能力。通过学习基于Java的服装商城管理系统项目,大学生可以在实践中学习和提升自己的能力,为以后的职业发展打下坚实基础。
32 2
基于Java+Springboot+Vue开发的服装商城管理系统
|
10天前
|
前端开发 JavaScript Java
SpringBoot项目部署打包好的React、Vue项目刷新报错404
本文讨论了在SpringBoot项目中部署React或Vue打包好的前端项目时,刷新页面导致404错误的问题,并提供了两种解决方案:一是在SpringBoot启动类中配置错误页面重定向到index.html,二是将前端路由改为hash模式以避免刷新问题。
52 1
|
8天前
|
前端开发 JavaScript Java
基于Java+Springboot+Vue开发的大学竞赛报名管理系统
基于Java+Springboot+Vue开发的大学竞赛报名管理系统(前后端分离),这是一项为大学生课程设计作业而开发的项目。该系统旨在帮助大学生学习并掌握Java编程技能,同时锻炼他们的项目设计与开发能力。通过学习基于Java的大学竞赛报名管理系统项目,大学生可以在实践中学习和提升自己的能力,为以后的职业发展打下坚实基础。
23 3
基于Java+Springboot+Vue开发的大学竞赛报名管理系统
|
9天前
|
前端开发 JavaScript Java
基于Java+Springboot+Vue开发的蛋糕商城管理系统
基于Java+Springboot+Vue开发的蛋糕商城管理系统(前后端分离),这是一项为大学生课程设计作业而开发的项目。该系统旨在帮助大学生学习并掌握Java编程技能,同时锻炼他们的项目设计与开发能力。通过学习基于Java的蛋糕商城管理系统项目,大学生可以在实践中学习和提升自己的能力,为以后的职业发展打下坚实基础。
21 3
基于Java+Springboot+Vue开发的蛋糕商城管理系统
|
9天前
|
前端开发 JavaScript Java
基于Java+Springboot+Vue开发的美容预约管理系统
基于Java+Springboot+Vue开发的美容预约管理系统(前后端分离),这是一项为大学生课程设计作业而开发的项目。该系统旨在帮助大学生学习并掌握Java编程技能,同时锻炼他们的项目设计与开发能力。通过学习基于Java的美容预约管理系统项目,大学生可以在实践中学习和提升自己的能力,为以后的职业发展打下坚实基础。
21 3
基于Java+Springboot+Vue开发的美容预约管理系统
|
9天前
|
JavaScript Java 关系型数据库
毕设项目&课程设计&毕设项目:基于springboot+vue实现的在线考试系统(含教程&源码&数据库数据)
本文介绍了一个基于Spring Boot和Vue.js实现的在线考试系统。随着在线教育的发展,在线考试系统的重要性日益凸显。该系统不仅能提高教学效率,减轻教师负担,还为学生提供了灵活便捷的考试方式。技术栈包括Spring Boot、Vue.js、Element-UI等,支持多种角色登录,具备考试管理、题库管理、成绩查询等功能。系统采用前后端分离架构,具备高性能和扩展性,未来可进一步优化并引入AI技术提升智能化水平。
毕设项目&课程设计&毕设项目:基于springboot+vue实现的在线考试系统(含教程&源码&数据库数据)
下一篇
无影云桌面