当broker不停的接收数据,然后磁盘上的数据越来越多,但是万一磁盘都放满了,那怎么办呢?
先简单给大家说一下,其实默认broker会启动后台线程,这个后台线程会自动去检查CommitLog、ConsumeQueue文件,因为这些文件都是多个的,比如CommitLog会有多个,ConsumeQueue也会有多个。
然后如果是那种比较旧的、比如超过72小时的文件,就会被删除掉,也就是说,默认来说,broker只会给你把数据保留3天而已,当然你也可以自己通过fileReservedTime来配置这个时间,要保留几天的时间。
这个定时检查过期数据文件的线程代码,在DefaultMessageStore这个类里,他的start()方法中会调用一个addScheduleTask()方法,里面会每隔10s定时调度执行一个后台检查任务,我们看下面的源码片段。
private void addScheduleTask() {
this.scheduledExecutorService.