spring boot操作rabbitmq的工作队列示例

项目基础结构参考:

spring boot操作rabbitmq的简单队列示例

源码:

生产者源码:https://gitee.com/constfafa/rabbitmq-producer-workqueue

消费者1源码:https://gitee.com/constfafa/rabbitmq-consumer-workqueue01

消费者2源码:https://gitee.com/constfafa/rabbitmq-consumer-workqueue02

 

工作过程

生产者每隔1秒发送一条信息到test_work_queue队列中

工作队列有两种工作方式:

 

轮询分发round-robin:

代码里进行了测试,将consumer01线程暂停4秒再执行,在round-robin情况下,仍会轮询分发。

 

结果:

生产者

 

消费者1:

由于sleep 4s,所以执行起来要比消费者2慢很多

 

 

 

消费者2:

虽然消费者2执行的快,但是由于设置为round-robin,不会多进行消息处理

 

 

 

公平分发fairdispatch:

告诉RabbitMQ不要同时将多个消息分派给一个工作者,换句话说,在某个工作者处理完一条消息并确认它之前,RabbitMQ不会给该工作者分派新的消息,而是将新的消息分派给下一个不是很繁忙的工作者 这就是fair dispatch

 

//如果不设置,默认是round-robin

factory.setPrefetchCount(1);

并且注释掉(为什么要注释掉呢?

factory.setAcknowledgeMode(AcknowledgeMode.MANUAL);

结果:

消费者1:

 

消费者2:

 

可以看到目前是fairdispatch方式

消息应答和消息持久化

注意以下两点:

1. 自动应答

为true说明队列把消息给消费者之后就将消息从其内存中删除。如果杀掉正在执行任务的消费者,就会丢失消息。

为false,关闭自动应答,说明队列把消息给消费者之后要等待消费者的确认处理完成消息。如果未收到消费者的确认处理完成消息,就会分发给其他消费者,保证消息不丢失。

factory.setAcknowledgeMode(AcknowledgeMode.MANUAL);

 

2. 消息持久化

如果rabbitmq挂了,那么存储在内存中的消息就会丢失了,这里涉及到durable的问题。将队列设置为durable实现消息持久化

    @Bean

    public Queue queue(){

        return new Queue(QUEUE_NAME,true);

    }

 

 

 

参考:

RabbitMQ入门教程 For Java【2】 - Work Queues
 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是 Spring Boot 整合 RabbitMQ 的详细示例: 1. 引入依赖 在 pom.xml 文件中引入以下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency> ``` 2. 配置 RabbitMQ 在 application.properties 文件中配置 RabbitMQ: ```properties spring.rabbitmq.host=localhost spring.rabbitmq.port=5672 spring.rabbitmq.username=guest spring.rabbitmq.password=guest ``` 3. 创建生产者 创建一个生产者(Producer)类,用于发送消息到 RabbitMQ: ```java @Component public class Producer { @Autowired private RabbitTemplate rabbitTemplate; public void send(String message) { rabbitTemplate.convertAndSend("myExchange", "myRoutingKey", message); } } ``` 4. 创建消费者 创建一个消费者(Consumer)类,用于从 RabbitMQ 接收消息: ```java @Component public class Consumer { @RabbitListener(queues = "myQueue") public void receive(String message) { System.out.println("Received message: " + message); } } ``` 5. 创建队列、交换机、绑定关系 使用 RabbitAdmin 类创建队列、交换机、绑定关系: ```java @Configuration public class RabbitConfig { @Autowired private RabbitTemplate rabbitTemplate; @PostConstruct public void setup() { RabbitAdmin rabbitAdmin = new RabbitAdmin(rabbitTemplate.getConnectionFactory()); Queue queue = new Queue("myQueue", true); DirectExchange exchange = new DirectExchange("myExchange", true, false); rabbitAdmin.declareQueue(queue); rabbitAdmin.declareExchange(exchange); rabbitAdmin.declareBinding(BindingBuilder.bind(queue).to(exchange).with("myRoutingKey")); } } ``` 6. 测试 在控制器(Controller)中调用生产者发送消息,测试消费者是否成功接收消息: ```java @RestController public class TestController { @Autowired private Producer producer; @GetMapping("/test") public String test() { producer.send("Hello, RabbitMQ!"); return "Message sent."; } } ``` 以上就是 Spring Boot 整合 RabbitMQ 的详细示例,希望能对你有所帮助。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值