【阅读笔记】rocketmq 概念与架构 (一)
介绍 rocketmq 框架与基本概念
1. 概念
1.1 namesrv(name server)
记录了 broker 集群信息,消息队列的信息以及 key-value 配置,见 RouteInfoManager 和 KVConfigManager。
可以由多个 namesrv 实例组成集群,但相互独立,没有信息交换。
1.2 broker
核心组件,负责存储所有的消息相关信息
- 支持主从模式
- 支持 master 写操作,只有当 master 读压力高于某个点(消息堆积),才会将读压力转给 salver
- 主从切换
4.5.0 版本之前无法做到主从切换。master 宕机,slaver
4.5.0 版本开始支持 master 宕机后可以切换到 slaver(4.5.0版本) - broker 提供了两种方式刷盘方式
- 同步刷盘:消息投放到 broker 之后,会在写入文件之后才返回成功
- 异步刷盘:消息投放 broker 成功后即可返回,同时启动另外的线程来存储消息
- 当发现broker压力较大时,可独立扩展 broker,只需要将 broker 地址注册到 namesrv 中即可
- 当其中一台broker机器宕机后,namesrv 不会顷刻间摘除心跳检测(多次无心跳检测才会摘除),而生产者/消费者亦会有轮询的方式,在数次请求无果后,会从可用列表中将该broker剔除掉,并将请求转发到另外的机器上
1.3 producer
生产者的作用就是将消息发送到 MQ,一个生产者发送业务应用系统生成的数据给Broker
RocketMQ提供多范式发送:同步,异步,一站式(OneWay)
1.4 producer group
生产者组,是将同样角色生产者的分组在一起。
同一生产组的不同生产者实例都会被 broker 告知提交或者回滚事务,以避免事务后源生产者崩溃
1.5 consumer
消费消息,从用户应用的角度看,有两种类型的消费者:
- PullConsumer 要客户主动拉取消息
- PushConsumer 推送消息(实际上还是用拉取实现)
1.6 Message Model 消息模型
有两种
- Clustering:同一消费组中只有一个消费者消费消息
- Broadcasting:消息将发往所有这个 topic 的订阅者,同一消费组中所有消费者都消费消息
1.7 consumer group
消费组,把同样角色的消费者分组到一起,即消费者组
如果消息模型是 Clustering ,那么同一消息,同一个 group 下只有一个 consumer 消费,
如果是 Broadcasting,同一消息,同一个 group 下所有 consumer 消费。
1 |
例如有一消息 A, 有 4 个 consumer c0~c3, 其中 |
1.8 message order
当使用DefaultMQPushConsumer时,需要确定消费消息的方式
- orderly:消费者将锁定每个MessageQueue,以确保每个消息按顺序被使用
- concurrently:消费者将同时使用这些消息
1.9 cluster
broker 集群,同一组 namesrv 可以注册多组 broker,每组 broker 就是一个 broker cluster。
cluster 通过 broker 的配置文件配置 brokerClusterName 指定
1.10 topic
消息按 Topic 组织,一个 Topic 可以存在于多个 Broker,一个 Topic 有多个 Consume Queue
1.11 consume queue
表示一个逻辑上的消息队列,这个队列一个元素就代表一个消息,一个元素包含了消息在 Commit log中的逻辑位置
1.12 offset
说明一个消息在 consume queue 中的下标,由0开始
2. 部署

部署方式有
- 单 master 模式
- 多 master 模式
- 多 master 多 slave 异步复制模式
- 多 master 多 slave 同步双写模式
单 master
只有一个 master节点
优点:配置简单,方便部署
缺点:这种方式风险较大,一旦 broker 重启或者宕机时,会导致整个服务不可用,不建议线上环境使用
多 master 模式
一个集群无 slave,全是 master,例如 2 个 master 或者 3 个 master
优点:配置简单,单个 master 宕机或重启维护对应用无影响。在磁盘配置为 RAID10 时,即使机器宕机不可恢复情况下,由与 RAID10 磁盘非常可靠,消息也不会丢(异步刷盘丢失少量消息,同步刷盘一条不丢),性能最高。
缺点:单台机器宕机期间,这台机器上未被消费的消息在机器恢复之前不可订阅,消息实时性会受到受到影响
备注:当使用多 master 无slave 的集群搭建方式时,master 的 brokerRole 配置必须为 ASYNC_MASTER。如果配置为 SYNC_MASTER,则 producer 发送消息时,返回值的 SendStatus 会一直是 SLAVE_NOT_AVAILABLE
多 master 多 slave模式(异步复制)
每个 master 配置一个 slave,有多对 master-slave。采用异步复制方式,主备有短暂消息延迟,毫秒级。
优点:即使磁盘损坏,消息丢失的非常少,且消息实时性不会受影响,因为 master 宕机后,消费者仍然可以从 slave 消费,此过程对应用透明。不需要人工干预。性能同多 master 模式几乎一样。
缺点:Master 宕机,磁盘损坏情况,会丢失少量消息。
多 master 多 slave模式(同步双写)
每个 master 配置一个 slave,有多对 master-slave。采用同步双写方式,主备都写成功,向应用返回成功。
优点:数据与服务都无单点, master 宕机情况下,消息无延迟,服务可用性与数据可用性都非常高
缺点:性能比异步复制模式略低,大约低 10%左右,发送单个消息的 RT 会略高。
4.5.0 之前主宕机后,备机不能自动切换为主机,4.5.0 开始支持自动切换功能
异步复制和同步双写的区别是,同步双写在写入消息后,会等待 slave 写完成才返回到应用。
【阅读笔记】rocketmq 概念与架构 (一)的更多相关文章
- 云时代架构阅读笔记六——Java内存模型详解(二)
承接上文:云时代架构阅读笔记五——Java内存模型详解(一) 原子性.可见性.有序性 Java内存模型围绕着并发过程中如何处理原子性.可见性和有序性这三个特征来建立的,来逐个看一下: 1.原子性(At ...
- 阅读笔记 1 火球 UML大战需求分析
伴随着七天国庆的结束,紧张的学习生活也开始了,首先声明,阅读笔记随着我不断地阅读进度会慢慢更新,而不是一次性的写完,所以会重复的编辑.对于我选的这本 <火球 UML大战需求分析>,首先 ...
- 《大象Think in UML》阅读笔记(三)
Think in UML 阅读笔记(三) 把从现实世界中记录下来的原始需求信息,再换成一种可以知道开发的表达方式.UML通过被称为之概念化的过程来建立适合计算机理解和实现的模型,这个模型被称为分析模型 ...
- Angular快速学习笔记(2) -- 架构
0. angular 与angular js angular 1.0 google改名为Angular js 新版本的,2.0以上的,继续叫angular,但是除了名字还叫angular,已经是一个全 ...
- 《Java多线程编程实战指南(核心篇)》阅读笔记
<Java多线程编程实战指南(核心篇)>阅读笔记 */--> <Java多线程编程实战指南(核心篇)>阅读笔记 Table of Contents 1. 线程概念 1.1 ...
- <<UML大战需求分析>>阅读笔记(2)
<<UML大战需求分析>>阅读笔记(2)> 此次读了uml大战需求分析的第三四章,我发现这本书讲的特别的好,由于这学期正在学习设计模式这本书,这本书就讲究对uml图的利用 ...
- Mongodb Manual阅读笔记:CH6 聚合
6 聚合 Mongodb Manual阅读笔记:CH2 Mongodb CRUD 操作Mongodb Manual阅读笔记:CH3 数据模型(Data Models)Mongodb Manual阅读笔 ...
- Mongodb Manual阅读笔记:CH4 管理
4 管理 Mongodb Manual阅读笔记:CH2 Mongodb CRUD 操作Mongodb Manual阅读笔记:CH3 数据模型(Data Models)Mongodb Manual阅读笔 ...
- QCon 2015 阅读笔记 - 其他精选主题
QCon 2015阅读笔记 QCon 2015 阅读笔记 - 移动开发最佳实践 QCon 2015 阅读笔记 - 团队建设 QCon 2015 阅读笔记 - 其他精选主题 以前分享过两个主题:移动开发 ...
随机推荐
- 绩效软件交流-ZQDJ
积分制(主管激励下属)短期任务积分 长期任务积分 制度积分 固定积分任务工作项 评估表 ,取中间值工时调整 工作表现 创新加分 难度加分 贡献加分 绩效分-积分(软件亮点) 分开做 没有管理员的中层 ...
- UML-如何进行对象设计?
之前的章节,学过了OOA,以及交互图+类图.本章主要讲述OOD.OOD就是面向对象设计,那如何进行对象设计? 概览 1.输入制品 注:这些制品并非都必要. 2.活动 1).针对输入的制品,采用什么样的 ...
- 题解 P2981 【[USACO10FEB]奶牛在冰Cows on Ice】
楼上的思路都是从一个石头找跳到另一个石头的路径,但其实这题可以对于上下左右四个方向分别做一个虚拟节点,然后只需要找虚拟节点左边的虚拟节点就行了 问题是:不会用set怎么办??? 其实可以发现用vect ...
- 远程SSH服务使用指南
Author Email Yaoyao Liu yaoyaoliu@msn.com 本文所有教程以ubuntu为例,对其他unix内核系统如Debian.CentOS.macOS等也适用. 目录 安装 ...
- Tensorflow学习教程------读取数据、建立网络、训练模型,小巧而完整的代码示例
紧接上篇Tensorflow学习教程------tfrecords数据格式生成与读取,本篇将数据读取.建立网络以及模型训练整理成一个小样例,完整代码如下. #coding:utf-8 import t ...
- diverta 2019 Programming Contest 2自闭记
A 签到(a-b problem不用贴了吧,以后atcoder小于300分题均不贴代码) B 发现选择的p,q一定是其中两点间的距离,于是可以O(n2)枚举两点,再O(n2)判断,其实可以做到O(n3 ...
- Kafka、RabbitMQ、RocketMQ等消息中间件的介绍和对比
本博客强烈推荐: Java电子书高清PDF集合免费下载 https://www.cnblogs.com/yuxiang1/p/12099324.html 前言 在分布式系统中,我们广泛运用消息中间件进 ...
- iTOP-3399开发板搭建Android编译坏境
基于迅为iTOP-3399开发板2.1 装 安装 d android 源码依赖包登录进 Ubuntu 系统,输入“ctrl+alt+t”,打开超级终端,使用“su root”命令,切换到 root ...
- vue开发之图片加载不出来问题解决
在使用vue开发项目的时候,经常会遇到的一个问题就是:图片加载不出来.下面是我总结的几种图片加载不出来的情况及解决办法. 一.项目打包完成后,打开整体空白 1.路径问题 原因 在vue+webpack ...
- JavaScript 的数据结构与算法
1数组 1.1方法列表 数组的常用方法如下: concat: 链接两个或者更多数据,并返回结果. every: 对数组中的每一项运行给定的函数,如果该函数对每一项都返回true,则返回true. fi ...