欢迎转载,转载请注明出处:http://www.cnblogs.com/lidabnu/p/5723280.html

消息中间件已经流行很长时间,一般情况下,不需要自己来从头研发、设计消息中间件,所以基础知识的目的是了解消息中间件解决什么问题、如何评估衡量消息中间件,以及掌握基本的相关术语。

专业术语

  • 消息:一种需要跨系统传递的数据结构
  • 生产者:产生消息的系统
  • 消费者:消费消息的系统
  • Broker:消息中转角色,负责消息的存储和转发,JMS规范中叫做Provider

应用场景

总结了一下,消息中间件用于解耦生产者与消费者,现在的理解,主要是降低生产者对消费者的“了解程度或要求程度”,具体来看:

  • 生产者不知道也不关心消费者是谁,不知道也不关心消费者是不是可能减少或者增多——我都不知道你是谁
  • 生产者知道消费者都有谁,但是消费者的技术实现方式完全不同:例如异构系统的集成——我知道你是谁,但是我对你怎么实现没啥要求
  • 生产者与消费者的系统质量属性要求不同或已支持的质量属性程度不同:——我知道你是谁,但是我对你实现的好坏没啥要求
    •   响应时间的要求不同:例如订单提交操作,生产者需要及时的响应最终用户,而订单的处理可以有相对较长的延时。
    •   可用性的不同:例如与某个外部系统集成,该外部系统的可用性相对不高,则可使用消息中间件来屏蔽此种不同。

消息中间件本身实现要解决的问题

从上面的应用场景来看,消息中间件需要解决以下问题,或者说要具备以下特性

  • 我不知道你是谁:支持发布-订阅模式,即支持动态的扩展和缩小消息消费者的范围
  • 我知道你是谁,我对你怎么实现没啥要求:与消费者、生产者的通信方式平台无关,提供多种技术的接入支持
  • 我知道你是谁,我对你实现的好坏没啥要求:
    • 具备足够的消息堆积能力:对应于消费者挂了
    • 对消息“至少消费一次”的保证:对应于消费者拿走一条消息后还没消费完就挂了

除上述要求外,还有一些通用的质量属性要求:

  • 高性能
  • 性能可伸缩
  • 可靠性:主要指消息的可靠性,各种情况下不应丢消息
  • 高可用:自身不能随便宕机
  • 易用性/可维护性:
    • API易用
    • 部署容易
    • 运维管理容易:便于与已有监控系统集成;便于细粒度管理消息中间件中的各种消息

以及一些异步化(消息中间件实质上是一种同步变异步)后所要解决的问题:

  • 消息顺序性保证:先生产的消息需要先消费,某些场景下是必须的

最后,上个学习过程中的脑图:

消息中间件MQ基础理论知识的更多相关文章

  1. 消息中间件 MQ

    复制粘贴于:https://blog.csdn.net/wqc19920906/article/details/82193316 一.消息中间件相关知识 1.概述 消息队列已经逐渐成为企业IT系统内部 ...

  2. 消息中间件MQ详解及四大MQ比较

    一.消息中间件相关知识 1.概述 消息队列已经逐渐成为企业IT系统内部通信的核心手段.它具有低耦合.可靠投递.广播.流量控制.最终一致性等一系列功能,成为异步RPC的主要手段之一.当今市面上有很多主流 ...

  3. 消息中间件MQ的学习境界和路线

    在<深入理解Java类加载机制,再也不用死记硬背了>里我提到了对于一门语言的"会"的三个层次.本篇将以知识地图的形式展现学习消息中间件MQ各个层次要掌握的内容. 知识地 ...

  4. java基础理论知识的一些总结

    在学习Java初期,由于我们是刚开始接触Java,我们不仅需要牢牢掌握Java的基础理论知识,来为我们后面对Java更深层次的学习打好基础,而且我们需要养成编程人的思想习惯.来我们一起来探索Java基 ...

  5. 消息中间件MQ

    消息中间件MQ:为方便预览,将思维导图上传至印象笔记,博客园直接上传图片受限于图片大小 https://app.yinxiang.com/shard/s24/nl/27262531/c3e137a5- ...

  6. MQ基础知识学习

    之前听人提起了MQ协议,我就去稍微了解了一下什么是MQ,和MQ的一些基础性的知识. 什么是MQ呢? 消息队列(MQ)是一种应用程序对应用程序的通信方法.应用程序通过写和检索出入列队的针对应用程序的数据 ...

  7. RabbitMQ系列(一)--消息中间件MQ如何去选择

    MQ在项目中的应用很普遍,本人所在项目组使用的是ActiveMQ,但是后面介绍的RabbitMQ... 一.应用场景 1.异步处理 2.流量削峰.秒杀 3.日志处理,推荐kafka 4.应用解耦 二. ...

  8. HTTPS学习笔记一----HTTPS的基础理论知识

    首先推荐一本书,<HTTP权威指南>我就是看这本书入门的,对http协议有了更好的理解,学习https的理论知识我认为需要了解以下几点,需要一步步的深入学习: 1.HTTPS的基本概念? ...

  9. Java基础理论知识

    package domain; public class Person { private String name; private int age; private char gender; pub ...

随机推荐

  1. 使用vs自带的wcf配置工具

    服务和行为是并列的 对应到配置文件中  wcf的配置在system.serviceModel中 可以有多个服务 一个服务会有一个主机以及多个终结点 主机包含多个基址 baseAddress 终结点,由 ...

  2. LintCode 38. Search a 2D Matrix II

    Write an efficient algorithm that searches for a value in an m x n matrix, return the occurrence of ...

  3. 新Azure 服务仪表盘!

    通过仪表盘, 我们可以查看当前状态和历史记录: http://www.windowsazure.cn/support/service-dashboard/

  4. 【转】提供android 5.0 AOSP源码下载

    http://blog.csdn.net/innost/article/details/41148335 android-5.0.tar.gz 115网盘礼包码:5lbcl16a1k7q http:/ ...

  5. Http 状态码完整说明

    在网站建设的实际应用中,容易出现很多小小的失误,就像mysql当初优化不到位,影响整体网站的浏览效果一样,其实,网站的常规http状态码的表现也是一样, 一些常见的状态码为: 200 - 服务器成功返 ...

  6. (转载)AS3领航系列教程 之 AS3程序的入口

    (转载)http://blog.csdn.net/wibrst/article/details/1861828 要实践本教程, 您需要安装以下软件:    Flash CS3 AS3程序的入口 众所周 ...

  7. linux之cut用法

    转载:http://www.cnblogs.com/dong008259/archive/2011/12/09/2282679.html cut是一个选取命令,就是将一段数据经过分析,取出我们想要的. ...

  8. HDOJ/HDU 1087 Super Jumping! Jumping! Jumping!(经典DP~)

    Problem Description Nowadays, a kind of chess game called "Super Jumping! Jumping! Jumping!&quo ...

  9. DevExpress的JavaScript脚本智能提示

    http://www.cnblogs.com/zhaozhan/archive/2011/06/08/2075767.html ASPxScriptIntelliSense.js在安装目录下的Comp ...

  10. HTML5 application cache

    Application Cache API (一) 基本应用 http://www.cnblogs.com/blackbird/archive/2012/06/12/2546751.html Appl ...