RocketMQ原理解析-producer 6.消息在broker落地之事物消息
2014-09-08 23:57
676 查看
1. 消息落地
commitLog针对事物消息的处理,消息的第20位开始的八位记录是的消息在逻辑队列中的queueoffset,但是针对事物消息为preparedType和rollbackType的存储的是事物状态表的索引偏移量2. 分发事物消息:
分发消息位置信息到ConsumeQueue: 事物状态为preparedType和rollbackType的消息不会将请求分发到ConsumeQueue中去,即不处理,所以不会被消息更新transactionstable table:如果是prepared消息记,通过TransactionStateService服务将消息加到存储事务状态的表格tranStateTable的文件中;如果是commitType和rollbackType消息, 修改事物状态表格tranStateTable中的消息状态。
记录Transaction Redo Log日志: 记录了 commitLogOffset, msgSize,preapredTransactionOffset, storeTimestamp。
3. 事物状态表
事物状态表是有MapedFileQueue将多个文件组成一个连续的队列,它的存储单元是定长为24个字节的数据,tranStateTableOffset可以认为是事物状态消息的个数,索引偏移量, 它的值是 tranStateTable.getMaxOffset()/ TSStoreUnitSize
3. 事物回查
定时回查线程会定时扫描(默认每分钟)每个存储事务状态的表格文件,遍历存储事务状态的表格记录
如果是已经提交或者回滚的消息调过过,
如果是prepared状态的如果消息小于事务回查至少间隔时间(默认是一分钟)跳出终止遍历
调transactionCheckExecuter.gotocheck方法向producer回查事物状态,
根据group随机选择一台producer
查询消息,根据commitLogOffset和msgSize到commitlog查找消息
向Producder发起请求,请求code类型为CHECK_TRANSACTION_STATE,producer的DefaultMQProducerImpl.checkTransactionState()方法来处理broker定时回调的请求,这里构建一个Runnable任务异步执行producer注册的回调接口,处理回调,在调endTransactionOneway向broker发送请求更新事物消息的最终状态
无Prepared消息,且遍历完,则终止扫描这个文件的定时任务
4. 事物消息的load&recover
TransactionStateService.load ()事物状态服务加载, 加载只是建立文件映射
redoLog队列恢复,加载本地redoLog文件
tranStateTable事物状态表, 加载本地tranStateTable文件
recover:
正常恢复:
利用tranRedoLog文件的recover
利用tranStateTable文件重建事物状态表
异常恢复:
先按照正常流程恢复TranRedo Log
commitLog异常恢复,commitLog根据checkpoint时间点重新生成 redolog,重新分发消息DispatchRequest,
分发消息到位置信息到ConsumeQueue
更新Transaction State Table
记录TransactionRedo Log
删除事物状态表tranStateTable
通过RedoLog全量恢复StateTable
重头扫描RedoLog, 过滤出所有prepared状态的消息, 将commit或者rollback的消息对应的prepared消息删除
重建StateTable, 将上面过滤出的prepared消息,添加到事物状态表文件中
这个事物状态表transstable的作用是定期(1分钟)将状态为prepared事物回查producer端redolog这个队列其实标记消费到哪了, 事物状态的恢复根本上是有commitlog来做的
相关文章推荐
- RocketMQ原理解析-producer 6.消息在broker落地之事物消息
- RocketMQ原理解析-producer 5.消息在broker落地之普通消息
- RocketMQ原理解析-producer 5.消息在broker落地之普通消息
- RocketMQ原理解析-producer 6.消息在broker落地之事物消息
- RocketMQ原理解析-producer 4.发送分布式事物消息
- RocketMQ原理解析-producer 4.发送分布式事物消息
- RocketMQ原理解析-producer 3.如何发送顺序消息
- RocketMQ原理解析-producer 2.如何发送消息
- RocketMQ原理解析-broker 2.消息存储
- RocketMQ原理解析-producer 5.消息在broker落地之普通消息
- RocketMQ原理解析-producer 3.如何发送顺序消息
- RocketMQ原理解析-broker 2.消息存储
- RocketMQ原理解析-broker 3.load&recover
- RocketMQ原理解析-consumer 5.push消费-顺序消费消息
- RocketMQ原理解析-broker 1. broker的启动
- RocketMQ原理解析-broker 4.HA & master slave
- RocketMQ原理解析-consumer 4.长轮询push消息—并发消费消息
- RocketMQ原理解析-broker 6.索引服务
- RocketMQ源码分析之Broker概述与同步消息发送原理与高可用设计及思考
- RocketMQ原理解析-producer 1.启动流程