【阅读笔记】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 阅读笔记 - 其他精选主题 以前分享过两个主题:移动开发 ...
随机推荐
- java使用ZipOutputStream批量压缩文件,并将文件分别放置不同文件夹压缩
package cn.cnnho.backstage.controller;import java.util.ArrayList; import java.util.List; import java ...
- vim,neovim 配置文件
插件管理用的是 https://github.com/junegunn/vim-plug 打开网址,会有示例,如何安装它本身,以及一些插件,照做,很容易完成 里面有两个可用的配置文件,cp_vimrc ...
- c#学习笔记01——引用&类
数据类型 值类型 bool 布尔值 True 或 False False byte 8 位无符号整数 0 到 255 0 char 16 位 Unicode 字符 U +0000 到 U +ffff ...
- ZJNU 1164 - 考试排名——中级
1.如果一个单元为0,表示没做过这题,不计入成绩 2.如果一个单位为负数,表示做错了这题,不计入成绩 所以只要一个单元为正数(不论是否有括号)都说明做出了这一题,计入成绩 将名字和成绩都当作字符串读入 ...
- Java--Json解析
普通Json {"code":"S0000", "describe":"数据正常返回", "result&qu ...
- Mongodb数据库(linux)——基础操作
简介 MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统.它是非关系型数据库,但其结构与MySQL又很相似,mysql中的表格,在这里被称为集合,mysql表格内的数据是一 ...
- python实现图书管理系统
# 用户注册 def logon(): print("欢迎来到图书管理系统注册页面~") username = input("请输入用户名:") if len( ...
- POJ-2031 Building a Space Station (球的最小生成树)
http://poj.org/problem?id=2031 Description You are a member of the space station engineering team, a ...
- maven坐标 加速下载
<repositories> <repository> <id>aliyun</id> <name>aliyun</name> ...
- Java统计内存
在目标代码前放置 Runtime r = Runtime.getRuntime(); r.gc(); long startMem = r.freeMemory(); // 开始时的剩余内存 目标代码执 ...