使用MQ消息隊(duì)列的優(yōu)缺點(diǎn)

1、前言

公司的項(xiàng)目一直都是在使用MQ的,但是由于使用的功能很簡(jiǎn)單,所以一直都是知其然不知其所以然,作為一個(gè)程序猿有必要了解每一個(gè)使用的技術(shù),為什么使用它?它的優(yōu)點(diǎn)是什么?缺點(diǎn)是什么?等等。。。

2.0使用mq的好處

2.1解耦與復(fù)用

系統(tǒng)A要發(fā)送一個(gè)消息到多個(gè)系統(tǒng),如果此時(shí)每增加一個(gè)系統(tǒng),系統(tǒng)A都需要通過(guò)修改源碼來(lái)增加接口,此時(shí)耦合非常高,但是如果中間使用消息隊(duì)列的話(huà),系統(tǒng)只需要發(fā)送一次到消息隊(duì)列,別的系統(tǒng)就能復(fù)用該信息,當(dāng)增加或刪除系統(tǒng)調(diào)用接口的時(shí)候,不需要額外的更新代碼。

2.2異步

用戶(hù)調(diào)用一個(gè)接口的時(shí)候,可能該接口調(diào)用了別的方法。例如:用戶(hù)注冊(cè)的時(shí)候,后臺(tái)可能需要調(diào)用:查詢(xún)數(shù)據(jù)庫(kù),插入數(shù)據(jù)庫(kù),發(fā)送郵件,發(fā)送用戶(hù)指南等等...

但是用戶(hù)可能并不需要后臺(tái)將所有的任務(wù)執(zhí)行完畢,那么此時(shí)在初入數(shù)據(jù)口后面加入mq隊(duì)列,用戶(hù)就能很快得到注冊(cè)成功的響應(yīng)而去做一些別的事情。mq的機(jī)制又能保證最終的一致性,所以使用起來(lái)很安全很穩(wěn)定。

2.3消峰

何為消峰,就是當(dāng)系統(tǒng)壓力過(guò)大的時(shí)候,讓系統(tǒng)壓力減小。如何做?

加入數(shù)據(jù)庫(kù)的讀寫(xiě)每秒3000,在高峰期,系統(tǒng)的訪(fǎng)問(wèn)達(dá)到了每秒10000。此時(shí)由于加入了消息隊(duì)列,所以不會(huì)出現(xiàn)激增的訪(fǎng)問(wèn)導(dǎo)致系統(tǒng)奔潰。

(注意,曉峰并不會(huì)讓用戶(hù)的等待時(shí)間減少,所以一般會(huì)跟異步搭配來(lái)使用)

3.0使用mq的缺點(diǎn)

3.1增加了復(fù)雜度與降低了可用性

本來(lái)系統(tǒng)之間直接通行調(diào)用接口就行了,但是引入了mq導(dǎo)致系統(tǒng)的復(fù)雜度大大增加,并且如果mq掛掉了,那么系統(tǒng)之間的通信就中斷了,導(dǎo)致整個(gè)系統(tǒng)的全部掛掉。

3.2一致性問(wèn)題

A系統(tǒng)處理完了發(fā)送到消息對(duì)流后直接返回成功了,用戶(hù)以為你這個(gè)請(qǐng)求就成功了;但是問(wèn)題是,其他系統(tǒng)消費(fèi)該消息后,如果當(dāng)中有一個(gè)系統(tǒng)出現(xiàn)了問(wèn)題,導(dǎo)致數(shù)據(jù)丟失。最后就會(huì)發(fā)生數(shù)據(jù)不一致等問(wèn)題。

4.0常見(jiàn)的mq的區(qū)別

特性ActiveMQRabbitMQRocketMQKafka

單機(jī)吞吐量萬(wàn)級(jí),吞吐量比RocketMQ和Kafka要低了一個(gè)數(shù)量級(jí)萬(wàn)級(jí),吞吐量比RocketMQ和Kafka要低了一個(gè)數(shù)量級(jí)10萬(wàn)級(jí),RocketMQ也是可以支撐高吞吐的一種MQ10萬(wàn)級(jí)別,這是kafka最大的優(yōu)點(diǎn),就是吞吐量高。一般配合大數(shù)據(jù)類(lèi)的系統(tǒng)來(lái)進(jìn)行實(shí)時(shí)數(shù)據(jù)計(jì)算、日志采集等場(chǎng)景

topic數(shù)量對(duì)吞吐量的影響??topic可以達(dá)到幾百,幾千個(gè)的級(jí)別,吞吐量會(huì)有較小幅度的下降這是RocketMQ的一大優(yōu)勢(shì),在同等機(jī)器下,可topic可以達(dá)到幾百,幾千個(gè)的級(jí)別,吞吐量會(huì)有較小幅度的下降這是RocketMQ的一大優(yōu)勢(shì),在同等機(jī)器下,可

時(shí)效性ms級(jí)微秒級(jí),這是rabbitmq的一大特點(diǎn),延遲是最低的ms級(jí)延遲在ms級(jí)以?xún)?nèi)

可用性高,基于主從架構(gòu)實(shí)現(xiàn)高可用性高,基于主從架構(gòu)實(shí)現(xiàn)高可用性非常高,分布式架構(gòu)非常高,kafka是分布式的,一個(gè)數(shù)據(jù)多個(gè)副本,少數(shù)機(jī)器宕機(jī),不會(huì)丟失數(shù)據(jù),不會(huì)導(dǎo)致不可用

消息可靠性有較低的概率丟失數(shù)據(jù)?經(jīng)過(guò)參數(shù)優(yōu)化配置,可以做到0丟失經(jīng)過(guò)參數(shù)優(yōu)化配置,消息可以做到0丟失

功能支持MQ領(lǐng)域的功能極其完備基于erlang開(kāi)發(fā),所以并發(fā)能力很強(qiáng),性能極其好,延時(shí)很低MQ功能較為完善,還是分布式的,擴(kuò)展性好功能較為簡(jiǎn)單,主要支持簡(jiǎn)單的MQ功能,在大數(shù)據(jù)領(lǐng)域的實(shí)時(shí)計(jì)算以及日志采集被大規(guī)模使用,是事實(shí)上的標(biāo)準(zhǔn)

優(yōu)劣勢(shì)總結(jié)非常成熟,功能強(qiáng)大,在業(yè)內(nèi)大量的公司以及項(xiàng)目中都有應(yīng)用偶爾會(huì)有較低概率丟失消息而且現(xiàn)在社區(qū)以及國(guó)內(nèi)應(yīng)用都越來(lái)越少,官方社區(qū)現(xiàn)在對(duì)ActiveMQ 5.x維護(hù)越來(lái)越少,幾個(gè)月才發(fā)布一個(gè)版本而且確實(shí)主要是基于解耦和異步來(lái)用的,較少在大規(guī)模吞吐的場(chǎng)景中使用erlang語(yǔ)言開(kāi)發(fā),性能極其好,延時(shí)很低;吞吐量到萬(wàn)級(jí),MQ功能比較完備而且開(kāi)源提供的管理界面非常棒,用起來(lái)很好用社區(qū)相對(duì)比較活的。RabbitMQ吞吐量會(huì)低一些,這是因?yàn)樗龅膶?shí)現(xiàn)機(jī)制比較重。erlang開(kāi)發(fā)很難去看懂源碼,你公司對(duì)這個(gè)東西的掌控很弱,基本職能依賴(lài)于開(kāi)源社區(qū)的快速維護(hù)和修復(fù)bug。接口簡(jiǎn)單易用,而且畢竟在阿里大規(guī)模應(yīng)用過(guò),可以做到大規(guī)模吞吐,性能也非常好,分布式擴(kuò)展也很方便,社區(qū)維護(hù)還可以,可靠性和可用性是ok的,還可以支撐大規(guī)模的topic數(shù)量。阿里出品都是java系的,我們可以自己閱讀源碼。kafka的特點(diǎn)其實(shí)很明顯,就是僅僅提供較少的核心功能,但是提供超高的吞吐量,ms級(jí)的延遲,極高的可用性以及可靠性,而且分布式可以任意擴(kuò)展同時(shí)kafka最好是支撐較少的topic數(shù)量即可,保證其超高吞吐量而且kafka唯一的一點(diǎn)劣勢(shì)是有可能消息重復(fù)消

5.0總結(jié)

所以在軟件的正常功能開(kāi)發(fā)中,并不需要去刻意的尋找消息隊(duì)列的使用場(chǎng)景,而是當(dāng)出現(xiàn)性能瓶頸時(shí),去查看業(yè)務(wù)邏輯是否存在可以異步處理的耗時(shí)操作,如果存在的話(huà)便可以引入消息隊(duì)列來(lái)解決。否則盲目的使用消息隊(duì)列可能會(huì)增加維護(hù)和開(kāi)發(fā)的成本卻無(wú)法得到可觀的性能提升,那就得不償失了。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 背景介紹 Kafka簡(jiǎn)介 Kafka是一種分布式的,基于發(fā)布/訂閱的消息系統(tǒng)。主要設(shè)計(jì)目標(biāo)如下: 以時(shí)間復(fù)雜度為O...
    高廣超閱讀 13,055評(píng)論 8 167
  • 以下是消息隊(duì)列以下的大綱,本文主要介紹消息隊(duì)列概述,消息隊(duì)列應(yīng)用場(chǎng)景和消息中間件示例(電商,日志系統(tǒng))。 本次分享...
    文檔隨手記閱讀 1,939評(píng)論 0 28
  • 轉(zhuǎn)自:http://www.cnblogs.com/linjiqin/p/5720865.html一、消息隊(duì)列概述...
    striveSmile閱讀 885評(píng)論 0 49
  • iOS定位服務(wù)設(shè)計(jì)實(shí)例一則 當(dāng)前,越來(lái)越多的移動(dòng)應(yīng)用基于LBS(位置服務(wù))構(gòu)建業(yè)務(wù),LBS可以說(shuō)是移動(dòng)應(yīng)用浪潮的基...
    fever105閱讀 1,965評(píng)論 1 4
  • 今天,我一時(shí)興起,想來(lái)談?wù)勔徊縿?dòng)漫,沒(méi)錯(cuò),就是如標(biāo)題所言的海賊王。還記得第一次接觸海賊王。應(yīng)該是在我初二的時(shí)候吧。...
    隨心了閱讀 242評(píng)論 5 1

友情鏈接更多精彩內(nèi)容