欢迎转载,转载请注明出处: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. 17.2.2 Replication Relay and Status Logs 复制Relay 和状态日志;

    17.2.2 Replication Relay and Status Logs 复制Relay 和状态日志: 17.2.2.1 The Slave Relay Log 17.2.2.2 Slave ...

  2. 子查询解嵌套in改写为exists

    SELECT * FROM (SELECT pubformdat0_.id id332_, pubformdat0_.domain_id domain2_332_, pubformdat0_.proc ...

  3. 在ubuntu12.04下编译android4.1.2添加JNI层出现问题

    tiny4412学习者,在ubuntu12.04下编译android4.1.2添加JNI层出现问题: (虚心请教解决方法) trouble writing output: Too many metho ...

  4. 【HDOJ】1242 Rescue

    BFS+优先级队列. #include <iostream> #include <cstdio> #include <cstring> #include <q ...

  5. 动态规划(计数DP):HDU 5136 Yue Fei's Battle

    Yue Fei's Battle Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 512000/512000 K (Java/Other ...

  6. Oracle 行拼接 wmsys.wm_concat扩展

    将多行数据拼接成一行: --wmsys.wm_concat group by a.flowid; 但有大小限制:字符串缓冲区太小,超过varchar 4000长度.扩展:更改返回类型为clob --T ...

  7. ubuntu64bits环境下搭建Opencl的环境

    此文介绍 ubuntu 平台下配置 AMD/ATI Opencl 环境,我是ubuntu 12.04. 主要分为六个步骤: 1. Take a look at your hardware to mak ...

  8. jQuery的文档操作方法

    jQuery 文档操作方法 这些方法对于 XML 文档和 HTML 文档均是适用的,除了:html(). 方法 描述 addClass() 向匹配的元素添加指定的类名. after() 在匹配的元素之 ...

  9. 04、生成 HTMLTestRunner 测试报告

    1.HTMLTestRunner 是 Python 标准库的 unittest 模块的一个扩展.它生成易于使用的 HTML 测试报告 1>下载HTMLTestRunner.py文件,地址为: h ...

  10. GC overhead limit exceeded解决

    java.lang.OutOfMemoryError: GC overhead limit exceeded解决   一.异常如下:Exception in thread "main&quo ...