消息中间件MQ基础理论知识
欢迎转载,转载请注明出处:http://www.cnblogs.com/lidabnu/p/5723280.html
消息中间件已经流行很长时间,一般情况下,不需要自己来从头研发、设计消息中间件,所以基础知识的目的是了解消息中间件解决什么问题、如何评估衡量消息中间件,以及掌握基本的相关术语。
专业术语
- 消息:一种需要跨系统传递的数据结构
- 生产者:产生消息的系统
- 消费者:消费消息的系统
- Broker:消息中转角色,负责消息的存储和转发,JMS规范中叫做Provider
应用场景
总结了一下,消息中间件用于解耦生产者与消费者,现在的理解,主要是降低生产者对消费者的“了解程度或要求程度”,具体来看:
- 生产者不知道也不关心消费者是谁,不知道也不关心消费者是不是可能减少或者增多——我都不知道你是谁
- 生产者知道消费者都有谁,但是消费者的技术实现方式完全不同:例如异构系统的集成——我知道你是谁,但是我对你怎么实现没啥要求
- 生产者与消费者的系统质量属性要求不同或已支持的质量属性程度不同:——我知道你是谁,但是我对你实现的好坏没啥要求
- 响应时间的要求不同:例如订单提交操作,生产者需要及时的响应最终用户,而订单的处理可以有相对较长的延时。
- 可用性的不同:例如与某个外部系统集成,该外部系统的可用性相对不高,则可使用消息中间件来屏蔽此种不同。
 
消息中间件本身实现要解决的问题
从上面的应用场景来看,消息中间件需要解决以下问题,或者说要具备以下特性
- 我不知道你是谁:支持发布-订阅模式,即支持动态的扩展和缩小消息消费者的范围
- 我知道你是谁,我对你怎么实现没啥要求:与消费者、生产者的通信方式平台无关,提供多种技术的接入支持
- 我知道你是谁,我对你实现的好坏没啥要求:
- 具备足够的消息堆积能力:对应于消费者挂了
- 对消息“至少消费一次”的保证:对应于消费者拿走一条消息后还没消费完就挂了
 
除上述要求外,还有一些通用的质量属性要求:
- 高性能
- 性能可伸缩
- 可靠性:主要指消息的可靠性,各种情况下不应丢消息
- 高可用:自身不能随便宕机
- 易用性/可维护性:
- API易用
- 部署容易
- 运维管理容易:便于与已有监控系统集成;便于细粒度管理消息中间件中的各种消息
 
以及一些异步化(消息中间件实质上是一种同步变异步)后所要解决的问题:
- 消息顺序性保证:先生产的消息需要先消费,某些场景下是必须的
最后,上个学习过程中的脑图:

消息中间件MQ基础理论知识的更多相关文章
- 消息中间件 MQ
		复制粘贴于:https://blog.csdn.net/wqc19920906/article/details/82193316 一.消息中间件相关知识 1.概述 消息队列已经逐渐成为企业IT系统内部 ... 
- 消息中间件MQ详解及四大MQ比较
		一.消息中间件相关知识 1.概述 消息队列已经逐渐成为企业IT系统内部通信的核心手段.它具有低耦合.可靠投递.广播.流量控制.最终一致性等一系列功能,成为异步RPC的主要手段之一.当今市面上有很多主流 ... 
- 消息中间件MQ的学习境界和路线
		在<深入理解Java类加载机制,再也不用死记硬背了>里我提到了对于一门语言的"会"的三个层次.本篇将以知识地图的形式展现学习消息中间件MQ各个层次要掌握的内容. 知识地 ... 
- java基础理论知识的一些总结
		在学习Java初期,由于我们是刚开始接触Java,我们不仅需要牢牢掌握Java的基础理论知识,来为我们后面对Java更深层次的学习打好基础,而且我们需要养成编程人的思想习惯.来我们一起来探索Java基 ... 
- 消息中间件MQ
		消息中间件MQ:为方便预览,将思维导图上传至印象笔记,博客园直接上传图片受限于图片大小 https://app.yinxiang.com/shard/s24/nl/27262531/c3e137a5- ... 
- MQ基础知识学习
		之前听人提起了MQ协议,我就去稍微了解了一下什么是MQ,和MQ的一些基础性的知识. 什么是MQ呢? 消息队列(MQ)是一种应用程序对应用程序的通信方法.应用程序通过写和检索出入列队的针对应用程序的数据 ... 
- RabbitMQ系列(一)--消息中间件MQ如何去选择
		MQ在项目中的应用很普遍,本人所在项目组使用的是ActiveMQ,但是后面介绍的RabbitMQ... 一.应用场景 1.异步处理 2.流量削峰.秒杀 3.日志处理,推荐kafka 4.应用解耦 二. ... 
- HTTPS学习笔记一----HTTPS的基础理论知识
		首先推荐一本书,<HTTP权威指南>我就是看这本书入门的,对http协议有了更好的理解,学习https的理论知识我认为需要了解以下几点,需要一步步的深入学习: 1.HTTPS的基本概念? ... 
- Java基础理论知识
		package domain; public class Person { private String name; private int age; private char gender; pub ... 
随机推荐
- Linux 命令备注
			linux 命令常用备注. 查看某文件大小,du -sk filename; 查看详细信息 ls -l; 查看系统分区 df -h; 查看系统信息 uname -a; 查看系统名称 hostname; ... 
- LM393,LM741可以用作电压跟随器吗?
			应该不能,比较器一般为OC门,输出要上拉VCC,在跟随状态下为深度负反馈,恐怕不能正常工作,会振荡的,不过你可以试下嘛. 
- 【HDOJ】2149 Public Sale
			看Discuss说是博弈论,没学到这个分类.不过仔细想了想,发现.如果m<=n,那么可能结果为m,m+1...n.否则,如果m%(n+1) == 0,那么无论如何都会输,因为无论先报价什么数,如 ... 
- bzoj1406
			这道题很有意思 我们解过线性同余方程,也解过同余方程 这个则是求x^2≡1 (mod p) 可以将问题转化为(x-1)(x+1)≡0 (mod p) 然后我们穷举一下p的约数i, 看i|x-1,p/i ... 
- bzoj1055
			不难想到是一个布尔型dp, 不难想到用f[i,j,k]表示区间[i,j]能否变为字母k 不难想到对于f[i,j,k],拆[i,j]成两个区间,然后穷举k的每一个变换来判断 感觉记忆化搜索写的比较顺,就 ... 
- Nginx 安装成 Windows 服务
			Nginx 安装成Windows 服务方法,具体方法如下 1. 下载nginx windows版本 http://www.nginx.org 2. 下载微软的2个工具: instsrv.exe.srv ... 
- [Java]重载,重写以及继承,多态的区别
			转自:http://android.blog.51cto.com/268543/53181 什么是多态?它的实现机制是什么呢?重载和重写的区别在那里?这就是这一次我们要回顾的四个十分重要的概念:继承. ... 
- java  JdbcTemplate源码
			package com.wl.filter; package org.javaresearch.jerch; import java.lang.reflect.Method; import java. ... 
- ASP.NET MVC 中将FormCollection与实体间转换方法 (转)
			将Action动作中传递的FormCollection转变成对应的实体,可以使用Controller的TryUpdateModel()方法. [HttpPost] public ActionResul ... 
- [App]Taste VS2015 && Android Studio
			逆水飞 尝试进行各种Android开发工具的安装以及大致流程对比 几个疑惑的地方 1)根据SDK的描述,应该是一个新版本的推出就有对应的包里面包含多个文件那么对于:SDK Platform.APIs. ... 
