欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

RabbitMQ 的消息持久化與 Spring AMQP 的實(shí)現(xiàn)詳解

 更新時(shí)間:2019年08月22日 09:16:34   作者:梁桂釗  
這篇文章主要介紹了RabbitMQ 的消息持久化與 Spring AMQP 的實(shí)現(xiàn)剖析詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

前言

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

  • 交換器必須是持久化。
  • 隊(duì)列必須是持久化的。
  • 消息必須是持久化的。

原生的實(shí)現(xiàn)方式

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

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

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

第二步,隊(duì)列的持久化。

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

第三步,消息的持久化。

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

Spring AMQP 的實(shí)現(xiàn)方式

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

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

// 參數(shù)1 name :交互器名
// 參數(shù)2 durable :是否持久化
// 參數(shù)3 autoDelete :當(dāng)所有消費(fèi)客戶端連接斷開(kāi)后,是否自動(dòng)刪除隊(duì)列
new TopicExchange(name, durable, autoDelete)

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

// 參數(shù)1 name :隊(duì)列名
// 參數(shù)2 durable :是否持久化
// 參數(shù)3 exclusive :僅創(chuàng)建者可以使用的私有隊(duì)列,斷開(kāi)后自動(dòng)刪除
// 參數(shù)4 autoDelete : 當(dāng)所有消費(fèi)客戶端連接斷開(kāi)后,是否自動(dòng)刪除隊(duì)列
new Queue(name, durable, exclusive, autoDelete);

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

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

一般情況下,我們會(huì)通過(guò)這種方式發(fā)送消息。

rabbitTemplate.convertAndSend(exchange, routeKey, message);

其中,調(diào)用了 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);
}

接著,用調(diào)用了 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);
 }

此時(shí),最關(guān)鍵的方法出現(xiàn)了,它是 convertMessageIfNecessary(final Object object)。

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

其中,關(guān)鍵的是 MessageProperties 類,它持久化的策略是 MessageDeliveryMode.PERSISTENT,因此它會(huì)初始化時(shí)默認(rèn)消息是持久化的。

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);
 }
}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 關(guān)于IDEA配置Hibernate中遇到的問(wèn)題解決

    關(guān)于IDEA配置Hibernate中遇到的問(wèn)題解決

    這篇文章主要給大家介紹了關(guān)于IDEA配置Hibernate中遇到的問(wèn)題,文中通過(guò)圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-05-05
  • Java算法之堆排序代碼示例

    Java算法之堆排序代碼示例

    這篇文章主要介紹了Java算法之堆排序代碼示例,具有一定參考價(jià)值,需要的朋友可以了解下。
    2017-11-11
  • Jrebel License Server 激活 IDEA-Jrebel-在線-離線-均適用(推薦)

    Jrebel License Server 激活 IDEA-Jrebel-在線-

    這篇文章主要介紹了Jrebel License Server 激活 IDEA-Jrebel-在線-離線-均適用,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-12-12
  • Java基礎(chǔ)-Java常量和常量值

    Java基礎(chǔ)-Java常量和常量值

    這篇文章主要介紹了Java基礎(chǔ)-Java常量和常量值,在程序中存在大量的數(shù)據(jù)來(lái)代表程序的狀態(tài),其中有些數(shù)據(jù)在程序運(yùn)行過(guò)程中值不能發(fā)生改變,這些數(shù)據(jù)在程序中被叫做常量,下面文章對(duì)Java常量和常量值的詳細(xì)內(nèi)容,需要的小伙伴可以參考一下
    2022-01-01
  • SpringBoot security安全認(rèn)證登錄的實(shí)現(xiàn)方法

    SpringBoot security安全認(rèn)證登錄的實(shí)現(xiàn)方法

    這篇文章主要介紹了SpringBoot security安全認(rèn)證登錄的實(shí)現(xiàn)方法,也就是使用默認(rèn)用戶和密碼登錄的操作方法,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-02-02
  • 一文帶你吃透JSP增刪改查實(shí)戰(zhàn)案例詳細(xì)解讀

    一文帶你吃透JSP增刪改查實(shí)戰(zhàn)案例詳細(xì)解讀

    這篇文章主要為大家詳細(xì)介紹了JSP中增刪改查實(shí)戰(zhàn)案例的相關(guān)知識(shí),文中的示例代碼講解現(xiàn)象,具有一定的借鑒價(jià)值,感興趣的小伙伴可以了解一下
    2023-03-03
  • 詳解Java中的悲觀鎖與樂(lè)觀鎖

    詳解Java中的悲觀鎖與樂(lè)觀鎖

    樂(lè)觀鎖對(duì)應(yīng)于生活中樂(lè)觀的人總是想著事情往好的方向發(fā)展,悲觀鎖對(duì)應(yīng)于生活中悲觀的人總是想著事情往壞的方向發(fā)展.這兩種人各有優(yōu)缺點(diǎn),不能不以場(chǎng)景而定說(shuō)一種人好于另外一種人,文中詳細(xì)介紹了悲觀鎖與樂(lè)觀鎖,需要的朋友可以參考下
    2021-05-05
  • springboot項(xiàng)目讀取resources目錄下的文件的9種方式

    springboot項(xiàng)目讀取resources目錄下的文件的9種方式

    本文主要介紹了springboot項(xiàng)目讀取resources目錄下的文件的9種方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • Security中的WebSecurityConfigurerAdapter詳解

    Security中的WebSecurityConfigurerAdapter詳解

    這篇文章主要介紹了Security中的WebSecurityConfigurerAdapter詳解,今天我們要進(jìn)一步的的學(xué)習(xí)如何自定義配置Spring?Security,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-07-07
  • Mybatis中關(guān)于自定義mapper.xml時(shí),參數(shù)傳遞的方式及寫(xiě)法

    Mybatis中關(guān)于自定義mapper.xml時(shí),參數(shù)傳遞的方式及寫(xiě)法

    這篇文章主要介紹了Mybatis中關(guān)于自定義mapper.xml時(shí),參數(shù)傳遞的方式及寫(xiě)法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12

最新評(píng)論