常见消息中间件对比
1.ActiveMQ
優(yōu)點(diǎn)
缺點(diǎn):
官方社區(qū)現(xiàn)在對(duì)ActiveMQ 5.x維護(hù)越來越少,較少在大規(guī)模吞吐的場(chǎng)景中使用。
2.Kafka
號(hào)稱大數(shù)據(jù)的殺手锏,談到大數(shù)據(jù)領(lǐng)域內(nèi)的消息傳輸,則繞不開Kafka,這款為大數(shù)據(jù)而生的消息中間件,以其百萬級(jí)TPS的吞吐量名聲大噪,迅速成為大數(shù)據(jù)領(lǐng)域的寵兒,在數(shù)據(jù)采集、傳輸、存儲(chǔ)的過程中發(fā)揮著舉足輕重的作用。
Apache Kafka它最初由LinkedIn公司基于獨(dú)特的設(shè)計(jì)實(shí)現(xiàn)為一個(gè)分布式的提交日志系統(tǒng)( a distributed commit log),之后成為Apache項(xiàng)目的一部分。
目前已經(jīng)被LinkedIn,Uber, Twitter, Netflix等大公司所采納。
優(yōu)點(diǎn)
缺點(diǎn):
RabbitMQ 2007年發(fā)布,是一個(gè)在AMQP(高級(jí)消息隊(duì)列協(xié)議)基礎(chǔ)上完成的,可復(fù)用的企業(yè)消息系統(tǒng),是當(dāng)前最主流的消息中間件之一。
3.RabbitMQ優(yōu)點(diǎn):
優(yōu)點(diǎn)
RabbitMQ缺點(diǎn):
4.RocketMQ
RocketMQ出自 阿里公司的開源產(chǎn)品,用 Java 語言實(shí)現(xiàn),在設(shè)計(jì)時(shí)參考了 Kafka,并做出了自己的一些改進(jìn)。
RocketMQ在阿里集團(tuán)被廣泛應(yīng)用在訂單,交易,充值,流計(jì)算,消息推送,日志流式處理,binglog分發(fā)等場(chǎng)景。
RocketMQ優(yōu)點(diǎn):
RocketMQ缺點(diǎn):
消息隊(duì)列選擇建議
1.Kafka
Kafka主要特點(diǎn)是基于Pull的模式來處理消息消費(fèi),追求高吞吐量,一開始的目的就是用于日志收集和傳輸,適合產(chǎn)生大量數(shù)據(jù)的互聯(lián)網(wǎng)服務(wù)的數(shù)據(jù)收集業(yè)務(wù)。
大型公司建議可以選用,如果有日志采集功能,肯定是首選kafka了。
2.RocketMQ
天生為金融互聯(lián)網(wǎng)領(lǐng)域而生,對(duì)于可靠性要求很高的場(chǎng)景,尤其是電商里面的訂單扣款,以及業(yè)務(wù)削峰,在大量交易涌入時(shí),后端可能無法及時(shí)處理的情況。
RoketMQ在穩(wěn)定性上可能更值得信賴,這些業(yè)務(wù)場(chǎng)景在阿里雙11已經(jīng)經(jīng)歷了多次考驗(yàn),如果你的業(yè)務(wù)有上述并發(fā)場(chǎng)景,建議可以選擇RocketMQ。
3.RabbitMQ
RabbitMQ :結(jié)合erlang語言本身的并發(fā)優(yōu)勢(shì),性能較好,社區(qū)活躍度也比較高,但是不利于做二次開發(fā)和維護(hù)。不過,RabbitMQ的社區(qū)十分活躍,可以解決開發(fā)過程中遇到的bug。
如果你的數(shù)據(jù)量沒有那么大,小公司優(yōu)先選擇功能比較完備的RabbitMQ。
以上,是Kafka、RocketMQ、RabbitMQ的優(yōu)劣勢(shì)比較。
總結(jié)
- 上一篇: proe5.0零件图添加文字问题
- 下一篇: 使用ruby获取yobo的飙升榜