当broker不停的接收数据,然后磁盘上的数据越来越多,但是万一磁盘都放满了,那怎么办呢?
先简单给大家说一下,其实默认broker会启动后台线程,这个后台线程会自动去检查CommitLog、ConsumeQueue文件,因为这些文件都是多个的,比如CommitLog会有多个,ConsumeQueue也会有多个。
然后如果是那种比较旧的、比如超过72小时的文件,就会被删除掉,也就是说,默认来说,broker只会给你把数据保留3天而已,当然你也可以自己通过fileReservedTime来配置这个时间,要保留几天的时间。
这个定时检查过期数据文件的线程代码,在DefaultMessageStore这个类里,他的start()方法中会调用一个addScheduleTask()方法,里面会每隔10s定时调度执行一个后台检查任务,我们看下面的源码片段。
private void addScheduleTask() {
this.
RocketMQ默认启动后台线程,每10s检查并删除超过72小时的CommitLog和ConsumeQueue文件。清理任务在凌晨4点或磁盘使用率超85%时触发,确保在磁盘满时避免故障。即使部分消息未消费,超过保留时间也会被删除。
订阅专栏 解锁全文
524

被折叠的 条评论
为什么被折叠?



