springboot 实现 RabbitMq 工作模式(Work queues) 案列

目录

1.先加入maven依赖

2. 在 application.yml 中配置rabbitmq的 连接信息:

3.队列配置,启动时创建队列

4.创建生产者

5.创建两个消费者

6.测试类中测试

结果 :控制台打印出消费者的log日志: 

这是Work Queues 的竞争模式,如果想要公平模式的效果,只需要将消费者中的 channel.basicQos(1)注释掉;


 

1.先加入maven依赖

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

2. 在 application.yml 中配置rabbitmq的 连接信息:

spring:
  rabbitmq:
    host: 127.0.0.1
    port: 5672
    username: guest
    password: guest
    listener:
      simple:
        acknowledge-mode: manual
        prefetch: 1

3.队列配置,启动时创建队列

@Configuration
public class RabbitMqConfig {
    @Bean
    public Queue createQueue(){
        return new Queue("hello-queue");
    }
}

4.创建生产者

@Component
public class Sender {

    @Autowired
    private AmqpTemplate amqpTemplate;

    public void sendTest(String msg){
        this.amqpTemplate.convertAndSend("hello-queue",msg);
    }
}

5.创建两个消费者

    第一个

@Component
public class Receiver {

    @SneakyThrows
    @RabbitListener(queues = "hello-queue")
    public void process(String msg,Channel channel,Message message){
        TimeUnit.SECONDS.sleep(1);
        channel.basicQos(1);
        System.out.println("receiver: "+msg);
        channel.basicAck(message.getMessageProperties().getDeliveryTag(),false);
    }
}

    第二个

@Component
public class Receiver2 {

    @SneakyThrows
    @RabbitListener(queues = "hello-queue")
    public void process(String msg, Channel channel, Message message){
        channel.basicQos(1);
        TimeUnit.SECONDS.sleep(2);
        System.out.println("receiver2: "+msg);
        channel.basicAck(message.getMessageProperties().getDeliveryTag(),false);
    }
}

 

6.测试类中测试

@SpringBootTest
class Rabbitmt1ApplicationTests {

    @Autowired
    private Sender sender;

    @Test
    void contextLoads() {
        sender.send("rabbit-mq-test");
    }

}

结果 :控制台打印出消费者的log日志: 

这是Work Queues 的竞争模式,如果想要公平模式的效果,只需要将消费者中的 channel.basicQos(1)注释掉;

 
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
消息队列 消息队列是一种解耦合的方式,其中生产者将消息发送到队列,而消费者从队列中接收并处理消息。消息队列可以用于异步处理,负载均衡和缓冲。 RabbitMQ RabbitMQ是一个开源的消息代理,它实现了AMQP(高级消息队列协议)标准。它可以在分布式系统中提供可靠的消息传递。 Spring Boot Spring Boot是一个基于Spring框架的开发框架,可以用于快速开发生产级别的应用程序。它提供了一种简化的方式来集成各种第三方库和框架,包括RabbitMQ实现 为了在Spring Boot中使用RabbitMQ,我们需要做以下几个步骤: 1. 添加RabbitMQ依赖 我们需要添加以下依赖来使用RabbitMQ: ``` <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency> ``` 2. 配置RabbitMQ连接 我们需要在application.properties文件中配置RabbitMQ连接: ``` spring.rabbitmq.host=localhost spring.rabbitmq.port=5672 spring.rabbitmq.username=guest spring.rabbitmq.password=guest ``` 3. 创建消息队列 我们需要在RabbitMQ中创建一个消息队列: ``` @Bean public Queue queue() { return new Queue("my-queue"); } ``` 4. 发送消息 我们可以使用RabbitTemplate来发送消息: ``` @Autowired private RabbitTemplate rabbitTemplate; public void send(String message) { rabbitTemplate.convertAndSend("my-queue", message); } ``` 5. 接收消息 我们可以使用@RabbitListener注解来接收消息: ``` @RabbitListener(queues = "my-queue") public void receive(String message) { System.out.println("Received message: " + message); } ``` 6. 测试 我们可以编写一个简单的测试来测试我们的应用程序是否能够正确地发送和接收消息: ``` @RunWith(SpringRunner.class) @SpringBootTest public class RabbitmqApplicationTests { @Autowired private RabbitmqService rabbitmqService; @Test public void test() throws Exception { rabbitmqService.send("Hello, RabbitMQ!"); Thread.sleep(1000); } } ``` 总结 在本教程中,我们学习了如何使用Spring Boot和RabbitMQ实现异步消息处理。我们了解了如何配置RabbitMQ连接,创建消息队列,发送和接收消息。现在您可以在自己的应用程序中使用RabbitMQ实现异步消息处理。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值