RabbitMQ —— 延迟队列
生活随笔
收集整理的這篇文章主要介紹了
RabbitMQ —— 延迟队列
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
RabbitMQ實現延遲隊列一:在隊列上設置TTL
Publish --> delaysync.exchange --> delay.5m.queue(延遲隊列) --> delay.exchange --> test.queue(正常隊列) --> Consumer
//延遲隊列start Map<String,Object> map = new HashMap<String,Object>(); map.put("x-message-ttl", 10000);//消息過期時間 map.put("x-max-length", 500000);//最大積壓的消息個數 map.put("x-dead-letter-exchange", "delay.exchange");//消息過期后會投遞到delay.exchange channel.queueDeclare("delay.5m.queue", true, false, false, map);RabbitMQ實現延遲隊列二:在消息上設置TTL
Publish --> default exchange --> delay_queue(延遲隊列) --> amq.direct --> message_ttl_queue(正常隊列) --> Consumer
隊列:
//延遲隊列 Map<String,Object> arguments = new HashMap<String,Object>(); arguments.put("x-dead-letter-exchange", "amq.direct");//消息過期后會投遞到amq.direct arguments.put("x-dead-letter-routing-key", "message_ttl_routingKey");//出現dead letter之后將重新按照指定的routing-key發送 channel.queueDeclare("delay_queue", true, false, false, arguments);消息發送:
//設置延遲屬性 AMQP.BasicProperties.Builder builder = new AMQP.BasicProperties.Builder(); //deliveryMode:將消息標記為持久(值為2)或瞬態(任何其他值) AMQP.BasicProperties properties = builder.expiration("10000").deliveryMode(2).build(); channel.basicPublish("", "delay_queue", properties, msg.getBytes());?
轉載于:https://www.cnblogs.com/yifanSJ/p/9007409.html
總結
以上是生活随笔為你收集整理的RabbitMQ —— 延迟队列的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: MyBatis中调用存储过程和函数
- 下一篇: 系统优化