91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何實現RabbitMQ的消息持久化與SpringAMQP

發布時間:2021-08-06 13:41:34 來源:億速云 閱讀:105 作者:小新 欄目:編程語言

這篇文章主要介紹如何實現RabbitMQ的消息持久化與SpringAMQP ,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

前言

要從奔潰的 RabbitMQ 中恢復的消息,我們需要做消息持久化。如果消息要從 RabbitMQ 奔潰中恢復,那么必須滿足三點,且三者缺一不可。

  • 交換器必須是持久化。

  • 隊列必須是持久化的。

  • 消息必須是持久化的。

原生的實現方式

原生的 RabbitMQ 客戶端需要完成三個步驟。

第一步,交換器的持久化。

// 參數1 exchange :交換器名
// 參數2 type :交換器類型
// 參數3 durable :是否持久化
channel.exchangeDeclare(EXCHANGE_NAME, "topic", true);

第二步,隊列的持久化。

// 參數1 queue :隊列名
// 參數2 durable :是否持久化
// 參數3 exclusive :僅創建者可以使用的私有隊列,斷開后自動刪除
// 參數4 autoDelete : 當所有消費客戶端連接斷開后,是否自動刪除隊列
// 參數5 arguments
channel.queueDeclare(QUEUE_NAME, true, false, false, null);

第三步,消息的持久化。

// 參數1 exchange :交換器
// 參數2 routingKey : 路由鍵
// 參數3 props : 消息的其他參數,其中 MessageProperties.PERSISTENT_TEXT_PLAIN 表示持久化
// 參數4 body : 消息體
channel.basicPublish("", queue_name, MessageProperties.PERSISTENT_TEXT_PLAIN, message.getBytes());

Spring AMQP 的實現方式

Spring AMQP 是對原生的 RabbitMQ 客戶端的封裝。一般情況下,我們只需要定義交換器的持久化和隊列的持久化。

其中,交換器的持久化配置如下。

// 參數1 name :交互器名
// 參數2 durable :是否持久化
// 參數3 autoDelete :當所有消費客戶端連接斷開后,是否自動刪除隊列
new TopicExchange(name, durable, autoDelete)

此外,還需要再配置隊列的持久化。

// 參數1 name :隊列名
// 參數2 durable :是否持久化
// 參數3 exclusive :僅創建者可以使用的私有隊列,斷開后自動刪除
// 參數4 autoDelete : 當所有消費客戶端連接斷開后,是否自動刪除隊列
new Queue(name, durable, exclusive, autoDelete);

至此,RabbitMQ 的消息持久化配置完畢。

那么,消息的持久化難道不需要配置么?確實如此,我們來看下源碼。

一般情況下,我們會通過這種方式發送消息。

rabbitTemplate.convertAndSend(exchange, routeKey, message);

其中,調用了 convertAndSend(String exchange, String routingKey, final Object object) 方法。

@Override
public void convertAndSend(String exchange, String routingKey, final Object object) throws AmqpException {
 convertAndSend(exchange, routingKey, object, (CorrelationData) null);
}

接著,用調用了 convertAndSend(String exchange, String routingKey, final Object object, CorrelationData correlationData) 方法。

public void convertAndSend(String exchange, String routingKey, final Object object, CorrelationData correlationData) throws AmqpException {
  send(exchange, routingKey, convertMessageIfNecessary(object), correlationData);
 }

此時,最關鍵的方法出現了,它是 convertMessageIfNecessary(final Object object)。

protected Message convertMessageIfNecessary(final Object object) {
 if (object instanceof Message) {
  return (Message) object;
 }
 return getRequiredMessageConverter().toMessage(object, new MessageProperties());
}

其中,關鍵的是 MessageProperties 類,它持久化的策略是 MessageDeliveryMode.PERSISTENT,因此它會初始化時默認消息是持久化的。

public class MessageProperties implements Serializable {
 public MessageProperties() {
  this.deliveryMode = DEFAULT_DELIVERY_MODE;
  this.priority = DEFAULT_PRIORITY;
 }
 static {
  DEFAULT_DELIVERY_MODE = MessageDeliveryMode.PERSISTENT;
  DEFAULT_PRIORITY = Integer.valueOf(0);
 }
}

以上是“如何實現RabbitMQ的消息持久化與SpringAMQP ”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

宝清县| 伊宁市| 成安县| 贵港市| 安康市| 邛崃市| 资溪县| 西藏| 姚安县| 淄博市| 融水| 北宁市| 云南省| 沾益县| 滨海县| 禄丰县| 麻栗坡县| 枣阳市| 吴忠市| 林口县| 铜陵市| 蒙自县| 惠水县| 平安县| 女性| 门源| 和顺县| 长春市| 上蔡县| 婺源县| 离岛区| 赫章县| 余姚市| 喀喇沁旗| 奎屯市| 洪湖市| 靖远县| 泸水县| 岱山县| 南投县| 迁西县|