自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

SpringBoot整合RabbitMQ延遲隊列&優(yōu)先級隊列詳解

開發(fā) 架構
發(fā)送消息發(fā)送到bs-queue上。由于消息消費端監(jiān)聽的是死信隊列,所以只需要等待指定的時間后消息會自動被轉發(fā)到死信隊列上(dead-queue)。

延遲隊列

延遲隊列:簡單說就是發(fā)送出去的消息經過給定的時間后,消費者才能看見消息(消費消息)。

這里簡單說下步驟:

  1. 創(chuàng)建一個隊列,如:bs-queue, 設置死信交換機(死信交換機路由key(這是可選的))及隊列,如:dead-exchange; 消息的消費端監(jiān)聽該dead-queue隊列。設置消息有效期參數x-message-ttl參數(值為自己需要延遲的時間,單位:毫秒)。
  2. 發(fā)送消息發(fā)送到bs-queue上。由于消息消費端監(jiān)聽的是死信隊列,所以只需要等待指定的時間后消息會自動被轉發(fā)到死信隊列上(dead-queue)。
  3. 消息的消費端監(jiān)聽dead-queu隊列即可。

優(yōu)先級隊列

優(yōu)先級隊列是在RabbitMQ3.5.0之后的版本才支持的。

具有高優(yōu)先級的隊列具有高的優(yōu)先權,優(yōu)先級高的消息具備優(yōu)先被消費的特權。

隊列的優(yōu)先級通過x-max-priority參數設置。

建立一個priority-exchange交換機,類型:direct。

圖片圖片

建立一個priority-queue隊列,并與priority-exchange綁定。

圖片圖片

設置x-max-priority參數的值為100,表示最大優(yōu)先級為100。

注意:x-max-priority參數的值應該介于1到255。建議使用1到10之間的隊列。如果設置的優(yōu)先級更大將使用更多的Erlang進程消耗更多的CPU資源。運行時調度也會受到影響。

接下來演示優(yōu)先級隊列

我們先只發(fā)送消息,然后再把消息的消費功能打開。

發(fā)送消息接口:

@GetMapping("/sendPriority")
public Object sendPriority(String msg, Integer priority) {
  ms.sendPriorityQueue(msg, priority) ;
  return "success" ;
}
public void sendPriorityQueue(String msg, Integer priority) {
  logger.info("準備發(fā)送消息:{}", msg);
  Message message = MessageBuilder.withBody(msg.getBytes()).setPriority(priority).build() ;
  rabbitTemplate.convertAndSend("priority-exchange", "pe.msg", message) ;
}

發(fā)送4條消息:

// 第一條消息
msg=第一條消息&priority=2 
// 第二條消息
msg=第二條消息&priority=10
// 第三條消息
msg=第三條消息&priority=1
// 第四條消息
msg=第四條消息&priority=7

查看消息隊列:

圖片圖片

消息消費端:

@RabbitListener(queues = { "priority-queue" })
@RabbitHandler
public void listenerPriority(Message message, Channel channel) {
  System.out.println("接受到消息.....income");
  byte[] body = message.getBody();
  MessageProperties mps = message.getMessageProperties();
  String content = new String(body, Charset.forName("UTF-8"));
  try {
    System.out.println("接受到消息來自交換機: 【" + mps.getReceivedExchange() + "】, 隊列:【" + mps.getConsumerQueue()+ "】:\n內容: " + content);
    channel.basicAck(message.getMessageProperties().getDeliveryTag(), true);
  } catch (Exception e) {
    e.printStackTrace();
    try {
      channel.basicReject(mps.getDeliveryTag(), false);
    } catch (IOException e1) {
      e1.printStackTrace() ;
    }
  }
}

啟動服務

圖片圖片

根據打印出的結果,正好是我們設置優(yōu)先級的順序輸出。

上面設置的消息優(yōu)先級都是在指定的范圍<100,如果消息的優(yōu)先級超過這個值會怎么樣呢?

發(fā)送8條消息:

// 第一條消息
msg=第一條消息&priority=2 
// 第二條消息
msg=第二條消息&priority=10
// 第三條消息
msg=第三條消息&priority=1
// 第四條消息
msg=第四條消息&priority=7
// 第五條消息
msg=第五條消息&priority=101

消費消息:

圖片圖片

同樣是按照順序輸出的。


責任編輯:武曉燕 來源: Spring全家桶實戰(zhàn)案例源碼
相關推薦

2024-03-18 00:00:03

RabbitMQ代碼延遲隊列

2023-10-10 13:39:53

Spring隊列優(yōu)化

2023-10-23 10:02:58

RabbitMQ延遲隊列

2023-09-05 15:48:14

RabbitMQ延遲隊列

2021-10-15 10:39:43

RabbitMQ隊列延遲

2021-06-11 06:10:09

Python數據結構算法

2024-03-11 07:46:40

React優(yōu)先級隊列二叉堆

2023-04-27 07:43:22

RabbitMQ重試隊列死信隊列

2024-04-19 00:47:07

RabbitMQ消息機制

2024-04-28 08:52:33

RabbitMQ延遲隊列延遲插件

2024-01-26 13:16:00

RabbitMQ延遲隊列docker

2010-09-01 14:10:36

CSS優(yōu)先級

2021-12-08 10:47:35

RabbitMQ 實現延遲

2021-04-23 21:40:33

Python優(yōu)先級調度器

2024-10-16 09:29:30

RabbitMQ延遲隊列

2024-11-05 16:58:21

RabbitMQ訂單超時取消延遲隊列

2024-12-25 09:32:06

2012-08-14 09:38:29

WAN優(yōu)化

2011-03-14 10:17:40

JavaScript

2023-07-26 13:21:10

點贊
收藏

51CTO技術棧公眾號