Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

名称time_index_memmory_proportion
描述指定TimeIndex在Read Memory中的所占的比例(占比越高查询效率越高)
类型double
默认值待确定0.2
更改后的生效方式重启服务器后生效

二、接口设计

org.apache.iotdb.db.rescon.TimeIndexManager

  • double TIME_INDEX_MEMORY_THRESHOLD:TimeIndex可使用的内存总量,值为allocateMemoryForRead * time_index_memory_proportion

  • ExecutorService downgradeThreadPool:用于执行TimeIndex降级任务的线程池

  • PriorityQueue<TsFileResource> sealedTimeIndex:维护所有已封口的TsFileResoruce,按照TimeIndex降级的优先级从高到低排序

  • long totalTimeIndexMemCost:所有已封口的TimeIndex占用的内存总量(非精确值,只计入封口文件的TimeIndex大小),当该值超过TIME_INDEX_MEMORY_THRESHOLD时触发索引降级

方法描述
registerSealedTimeIndex

语法:public synchronized ITimeIndex registerSealedTimeIndex(TsFileResource resource)

功能:将已封口的TsFileResoruce添加到sealedTimeIndex中,并在totalTimeIndexMemCost中添加内存占用

chooseTimeIndexsToFlush


三、详细设计