成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

如何實(shí)現(xiàn)RabbitMQ的消息持久化與SpringAMQP

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

公司主營業(yè)務(wù):網(wǎng)站制作、做網(wǎng)站、移動(dòng)網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。創(chuàng)新互聯(lián)公司是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)公司推出達(dá)孜免費(fèi)做網(wǎng)站回饋大家。

前言

要從奔潰的 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ì)列,斷開后自動(dòng)刪除
// 參數(shù)4 autoDelete : 當(dāng)所有消費(fè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)客戶端連接斷開后,是否自動(dòng)刪除隊(duì)列
new TopicExchange(name, durable, autoDelete)

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

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

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

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

一般情況下,我們會(huì)通過這種方式發(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);
 }
}

以上是“如何實(shí)現(xiàn)RabbitMQ的消息持久化與SpringAMQP ”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

網(wǎng)站標(biāo)題:如何實(shí)現(xiàn)RabbitMQ的消息持久化與SpringAMQP
路徑分享:http://jinyejixie.com/article26/pshjjg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供服務(wù)器托管、小程序開發(fā)面包屑導(dǎo)航、企業(yè)建站網(wǎng)站導(dǎo)航、網(wǎng)站策劃

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名
水城县| 平远县| 娄烦县| 建瓯市| 新化县| 南城县| 简阳市| 漯河市| 乌兰察布市| 枣阳市| 家居| 中宁县| 甘肃省| 桂阳县| 信丰县| 庄河市| 青川县| 甘孜| 灌云县| 洛隆县| 清水县| 扶余县| 盐津县| 红原县| 大姚县| 尉犁县| 湄潭县| 全州县| 金寨县| 大洼县| 藁城市| 易门县| 平远县| 二手房| 姚安县| 绥滨县| 湟中县| 江山市| 商南县| 诸暨市| 开阳县|