Kafka, ZeroMQ, RabbitMQ, ActiveMQ ,Redis
来源:互联网 发布:网络对抗能力 编辑:程序博客网 时间:2024/05/22 05:10
http://www.infoq.com/cn/articles/kafka-analysis-part-1/
Kafka是一种分布式的,基于发布/订阅的消息系统。主要设计目标如下:
Kafka是一种分布式的,基于发布/订阅的消息系统。主要设计目标如下:
- 以时间复杂度为O(1)的方式提供消息持久化能力,即使对TB级以上数据也能保证常数时间复杂度的访问性能。
- 高吞吐率。即使在非常廉价的商用机器上也能做到单机支持每秒100K条以上消息的传输。
- 支持Kafka Server间的消息分区,及分布式消费,同时保证每个Partition内的消息顺序传输。
- 同时支持离线数据处理和实时数据处理。
- Scale out:支持在线水平扩展。
- RabbitMQ
RabbitMQ是使用Erlang编写的一个开源的消息队列,本身支持很多的协议:AMQP,XMPP, SMTP, STOMP,也正因如此,它非常重量级,更适合于企业级的开发。同时实现了Broker构架,这意味着消息在发送给客户端时先在中心队列排队。对路由,负载均衡或者数据持久化都有很好的支持。 - Redis
Redis是一个基于Key-Value对的NoSQL数据库,开发维护很活跃。虽然它是一个Key-Value数据库存储系统,但它本身支持MQ功能,所以完全可以当做一个轻量级的队列服务来使用。对于RabbitMQ和Redis的入队和出队操作,各执行100万次,每10万次记录一次执行时间。测试数据分为128Bytes、512Bytes、1K和10K四个不同大小的数据。实验表明:入队时,当数据比较小时Redis的性能要高于RabbitMQ,而如果数据大小超过了10K,Redis则慢的无法忍受;出队时,无论数据大小,Redis都表现出非常好的性能,而RabbitMQ的出队性能则远低于Redis。 - ZeroMQ
ZeroMQ号称最快的消息队列系统,尤其针对大吞吐量的需求场景。ZeroMQ能够实现RabbitMQ不擅长的高级/复杂的队列,但是开发人员需要自己组合多种技术框架,技术上的复杂度是对这MQ能够应用成功的挑战。ZeroMQ具有一个独特的非中间件的模式,你不需要安装和运行一个消息服务器或中间件,因为你的应用程序将扮演这个服务器角色。你只需要简单的引用ZeroMQ程序库,可以使用NuGet安装,然后你就可以愉快的在应用程序之间发送消息了。但是ZeroMQ仅提供非持久性的队列,也就是说如果宕机,数据将会丢失。其中,Twitter的Storm 0.9.0以前的版本中默认使用ZeroMQ作为数据流的传输(Storm从0.9版本开始同时支持ZeroMQ和Netty作为传输模块)。 - ActiveMQ
ActiveMQ是Apache下的一个子项目。 类似于ZeroMQ,它能够以代理人和点对点的技术实现队列。同时类似于RabbitMQ,它少量代码就可以高效地实现高级应用场景。 - Kafka/Jafka
Kafka是Apache下的一个子项目,是一个高性能跨语言分布式发布/订阅消息队列系统,而Jafka是在Kafka之上孵化而来的,即Kafka的一个升级版。具有以下特性:快速持久化,可以在O(1)的系统开销下进行消息持久化;高吞吐,在一台普通的服务器上既可以达到10W/s的吞吐速率;完全的分布式系统,Broker、Producer、Consumer都原生自动支持分布式,自动实现负载均衡;支持Hadoop数据并行加载,对于像Hadoop的一样的日志数据和离线分析系统,但又要求实时处理的限制,这是一个可行的解决方案。Kafka通过Hadoop的并行加载机制统一了在线和离线的消息处理。Apache Kafka相对于ActiveMQ是一个非常轻量级的消息系统,除了性能非常好之外,还是一个工作良好的分布式系统。
0 0
- Kafka, ZeroMQ, RabbitMQ, ActiveMQ ,Redis
- RabbitMQ、Redis、ZeroMQ、ActiveMQ、Kafka/Jafka对比
- rabbitMQ、activeMQ、zeroMQ、Kafka、Redis 比较
- rabbitMQ、activeMQ、zeroMQ、Kafka、Redis 比较
- rabbitMQ、activeMQ、zeroMQ、Kafka、Redis 比较
- rabbitMQ、activeMQ、zeroMQ、Kafka、Redis 比较
- rabbitMQ、activeMQ、zeroMQ、Kafka、Redis 的比较
- RabbitMq、ActiveMq、ZeroMq、kafka
- rabbitMQ、activeMQ、zeroMQ、Kafka、Redis 比较,资料汇总
- RabbitMq、ActiveMq、ZeroMq、kafka之间的比较
- RabbitMq、ActiveMq、ZeroMq 和 kafka 比较
- RabbitMq、ActiveMq、ZeroMq、kafka之间比较
- RabbitMq、ActiveMq、ZeroMq、kafka 之间的比较
- RabbitMq、ActiveMq、ZeroMq、kafka之间的比较
- RabbitMq、ActiveMq、ZeroMq、kafka之间的比较
- RabbitMq、ActiveMq、ZeroMq、kafka之间的比较,,
- RabbitMq、ActiveMq、ZeroMq、kafka之间的比较,资料汇总
- RabbitMq、ActiveMq、ZeroMq、kafka之间的比较,资料汇总
- flume案例集锦
- iOS下的Masonry适配
- C++ Notes-Inheritance-01
- ajax请求 session过期跳转首页的两种处理方式
- Android.mk详解
- Kafka, ZeroMQ, RabbitMQ, ActiveMQ ,Redis
- #277 – 显示图片的时候注意图片自己的Dpi信息(Images May Have Embedded DpiX and DpiY Information)
- ios /SourceCache/DVTiOSFrameworks/DVTiOSFrameworks-5053/DTDeviceKitBase/DTDeviceKitBase_Utilities.m
- 唐山银行_企业网银_OSGI勾宝
- Flask Web 开发 关注者
- scala学习手记- 模式匹配
- zookeeper和dubbo的关系
- 2、RIOT在ubuntu中的环境搭建和源码下载
- 【英语单词】干货大集合!!