7.RabbitMQ 消费者Consumer实现

1、创建Consumer的接口RabbitMqService:

package com.java996.consumer.service;

public interface RabbitMqService {

    /**
     * 接收消息
     */
    public void receiveMessage();
}

2、创建Consumer的接口的实现RabbitMqServiceImpl:

package com.java996.consumer.service.impl;

import com.java996.consumer.service.RabbitMqService;
import com.java996.producer.config.RabbitMqConfig;
import org.springframework.amqp.core.AmqpTemplate;
import org.springframework.stereotype.Service;

import javax.annotation.Resource;

@Service("RabbitMqService")
public class RabbitMqServiceImpl implements RabbitMqService {

    @Resource
    private AmqpTemplate amqpTemplate;

    /**
     * receiveAndConvert(String queueName),参数说明:队列名称
     */
    @Override
    public void receiveMessage() {
        String message = (String)amqpTemplate.receiveAndConvert(RabbitMqConfig.DIRECT_QUEUE);
        System.out.println("接收到的消息:"+message);
    }
}

3、启动,测试接收消息

package com.java996.consumer;

import com.java996.consumer.service.RabbitMqService;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.ConfigurableApplicationContext;

@SpringBootApplication
public class ConsumerApp {
    public static void main(String[] args) {
        ConfigurableApplicationContext context = SpringApplication.run(ConsumerApp.class,args);
        RabbitMqService rabbitMqService = (RabbitMqService) context.getBean("RabbitMqService");
        rabbitMqService.receiveMessage();
    }
}

4、结果:
在这里插入图片描述
这种方式只能拿到一条数据,所以需要换一种方式

5、监听队列,首先保证队列中有多条消息,启动项中的消费代码已注释或删除

@Override
@RabbitListener(queues = {RabbitMqConfig.DIRECT_QUEUE}) //监听队列
public void receiveMessage2(String message) {
    System.out.println("接收到的消息:"+message);
}

6、结果:
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
RabbitMQ 是一个开源的消息队列系统,它使用 AMQP (Advanced Message Queuing Protocol) 协议作为其核心。在 RabbitMQ 中,消息的传递流程通常包括以下几个关键步骤: 1. **生产者(Producer)**:创建消息并将其放入队列中。生产者可以是一个应用程序或服务,它发送消息到 RabbitMQ,可以选择单个队列或交换机(Exchange)。 2. **队列(Queue)**:消息被发送到一个或多个队列中,每个队列都是独立的,它们存储和管理接收到的消息。队列是异步处理的,意味着消息不会立即被消费者消费,而是暂存。 3. **路由规则(Routing Key)**:如果使用交换机,生产者指定一个路由键,交换机会基于此规则将消息路由到相应的队列。 4. **消费者(Consumer)**:消费者从队列中取出并处理消息。消费者可以有多个实例同时监听队列,这称为消费者组(Consumer Group),共享消息并实现负载均衡。 5. **确认机制(Acknowledgment)**:RabbitMQ 支持事务性确认,消费者消费完消息后可以发送确认,如果生产者没有收到确认,消息可能会重新入队等待处理。 6. **持久化(Persistence)**:RabbitMQ 可以使消息持久化存储,即使服务器重启,消息也不会丢失,直到被成功消费或超时删除。 7. **错误恢复(Error Recovery)**:RabbitMQ 有强大的错误恢复机制,包括重试、死信队列等,以保证在出现问题时消息能够正确处理。 8. **管理界面(Management Console)**:RabbitMQ 提供了一个可视化的 Web 界面,管理员可以通过它监控和管理集群状态、队列和交换机等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值