RocketMQ Broker
概述
- Broker即是物理上的概念,也是逻辑上的概念。多个物理Broker通过IP:PORT区分,多个逻辑Broker通过BrokerName区分。
- 多个逻辑Broker组成Cluster。
- Broker与Topic是多对多的关系。
- Broker自身包含一个使用10911端口的NettyServer、一个10909的NettyServer,以及一个NettyClient。
- HA通过10912端口提供服务,用于Broker内部各个部分的数据传输。
- Broker是最重要的部分,包括持久化消息、Broker集群一致性(HA)、保存历史消息、保存Consumer消费偏移量、索引创建等。
- Producer发送来的消息最终会通过CommitLog序列化到硬盘,执行序列化逻辑的类为AppendMessageCallback接口的实现类。
- Broker序列化消息是顺序写,序列化文件保存在userHome/store/commitlog目录下,文件名为总偏移量。
- 默认为异步刷盘、提交日志单个文件1个G、单个consumer队列文件为不到6M
处理Producer消息
Broker通过SendMessageProcessor.processRequest()处理Producer生成的消息,处理过程如下:
- 反序列化消息头为SendMessageRequestHeader对象实例。
- 构建消息上下文
- 执行前置钩子程序
- 处理message
- 判断当前系统时间是否在Broker配置的服务时间之后,只有条件成立broker才提供服务。