码迷,mamicode.com
首页 > 其他好文 > 详细

消息中间件选型

时间:2015-12-03 00:14:01      阅读:193      评论:0      收藏:0      [点我收藏+]

标签:

    消息中间件对目前大中型互联网来说是非常重要的,在业务数据流动中仅次于RPC服务调用,担负着越来越复杂的网站业务从主流程上解耦的重要责任;
    从目前互联网对消息中间件的需求来看应该分为两种类型,一种是和钱相关的需求,一种是和钱无关的需求;和钱相关的需求消息的可靠性是放在第一位的,和钱无关的需求是速度放在第一位的,但这两种需求又是矛盾的,很难设计出一种既可靠又高效的系统,除非将两套方案捏合成一个系统,通过配置来选择不同方案,但从实现上说还是两种实现。所以目前业界有几种不同的设计方式来满足不同的需求。

下面看几种典型的实现方案:

1、以ActiveMQ为代表的可靠性优先的设计原理:简单、轻量、易部署(JMS Provider负责消息路由)

技术分享

     此种方案将所有的消息数据和消息的发送状态都存储在消息服务器上,可以在消息服务上通过多种手段来保证消息的可靠性,但增加了众多复杂的可靠性保证手段后,消息从发布者到订阅者的速度势必会受到影响;此种方式发布者将消息推向消息服务器,消息服务器再将消息推向订阅者,为消息发送策略提供了很好的可扩展性;

ActiveMQ参见:http://manzhizhen.iteye.com/category/318342

2、以KafKa为代表的速度优先的设计原理

技术分享

     此种方式将消息的发送状态保存在客户端,同时客户端用拉的模式从消息服务器上获取消息,由于是顺序读,同时还采取了很多保证速度的策略,如zero-copy,所以此种方案速度比较快,但牺牲了很多可靠性方面的保证,比较适合Web2.0网站,这些网站对消息的可靠性要求不是很高,同时由于产生了大量的和用户状态相关的消息,需要一个高效的系统来处理这些消息;另外这种方案也比较适合日志消息的收集;

3、传统的解耦方案

技术分享

消息队列中间件的技术选型分析请参见:http://www.cnblogs.com/lsx1993/p/4657897.html

消息中间件选型

标签:

原文地址:http://www.cnblogs.com/moonandstar08/p/5014806.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!