SpringAMQP Work Queue 工作队列

消息模型:

代码模拟:

相较于之前的基础队列,该队列新增了消费者 不再是一个,所以我们通过代码模拟出两个consumer消费者。在原来的消费者类里写两个方法 其中消费者1效率高 消费者2效率低

@RabbitListener(queues = "simple.queue")
    public void lintestWorkQueue50(String mes) throws InterruptedException {
        System.out.println("消费者1接收到了消息:" + mes +"     "+ LocalDateTime.now());
        Thread.sleep(20);
    }


    @RabbitListener(queues = "simple.queue")
    public void lintestWorkQueue10(String mes) throws InterruptedException {
        System.err.println("消费者2接收到了消息:" + mes + "     "+LocalDateTime.now());
        Thread.sleep(200);
    }

在publisher提供者编写测试方法 一次发送50条消息 

发送后让观察控制台消费者处理情况 会发现两者处理的效率不一样但是处理的消息是平均分配的,一人25条,这是因为Rabbit有个预取机制,不管执行消费者效率,消费者都会提前在队列里预取一个消息,最后效果就是平均分配。

这个预取机制可以在yml配置里修改。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用 Spring AMQP 和 Redis 消息队列可以实现分布式系统中的异步通信,提高系统的性能和可靠性。 首先,你需要在 Spring Boot 项目中添加 Spring AMQP 和 Redis 的依赖。在 pom.xml 文件中添加以下依赖: ```xml <dependencies> <!-- Spring AMQP --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency> <!-- Redis --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> </dependencies> ``` 接下来,你需要配置 RabbitMQ 和 Redis 的连接信息。在 application.properties 文件中添加以下配置: ```properties # RabbitMQ spring.rabbitmq.host=localhost spring.rabbitmq.port=5672 spring.rabbitmq.username=guest spring.rabbitmq.password=guest # Redis spring.redis.host=localhost spring.redis.port=6379 ``` 然后,你需要创建一个 RabbitMQ 的消息队列和一个 Redis 的消息队列。在 Spring Boot 项目中,你可以使用 @Bean 注解来创建这些队列。 ```java @Configuration public class QueueConfiguration { @Bean public Queue rabbitQueue() { return new Queue("rabbit.queue"); } @Bean public RedisQueue redisQueue() { return new RedisQueue("redis.queue"); } } ``` 在上面的代码中,我们创建了一个名为 "rabbit.queue" 的 RabbitMQ 队列和一个名为 "redis.queue" 的 Redis 队列。 接下来,你可以在你的代码中使用 RabbitTemplate 和 RedisTemplate 来发送消息。下面是一个简单的例子: ```java @Service public class MessageService { @Autowired private RabbitTemplate rabbitTemplate; @Autowired private RedisTemplate<String, String> redisTemplate; public void sendMessageToRabbit(String message) { rabbitTemplate.convertAndSend("rabbit.queue", message); } public void sendMessageToRedis(String message) { redisTemplate.convertAndSend("redis.queue", message); } } ``` 在上面的代码中,我们创建了一个 MessageService 类来发送消息。我们使用 rabbitTemplate.convertAndSend 方法来发送消息到 RabbitMQ 队列,使用 redisTemplate.convertAndSend 方法来发送消息到 Redis 队列。 最后,你需要在你的代码中使用 @RabbitListener 和 @RedisQueueListener 注解来接收消息。下面是一个简单的例子: ```java @Service public class MessageService { @Autowired private RabbitTemplate rabbitTemplate; @Autowired private RedisTemplate<String, String> redisTemplate; @RabbitListener(queues = "rabbit.queue") public void receiveMessageFromRabbit(String message) { System.out.println("Received message from RabbitMQ: " + message); } @RedisQueueListener(queues = "redis.queue") public void receiveMessageFromRedis(String message) { System.out.println("Received message from Redis: " + message); } } ``` 在上面的代码中,我们使用 @RabbitListener 注解来监听 RabbitMQ 队列中的消息,使用 @RedisQueueListener 注解来监听 Redis 队列中的消息。 总之,使用 Spring AMQP 和 Redis 消息队列可以方便地实现分布式系统中的异步通信。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值