sofastack/sofa-jraft

RFC: multi-generation log cache

Open

#854 创建于 2022年6月23日

在 GitHub 查看
 (9 评论) (1 反应) (0 负责人)Java (3,406 star) (1,125 fork)batch import
enhancementhelp wanted

描述

RFC: multi-generation log cache

As discussion in #840 , jraft keeps a cache for latest log entries, it's unlimited and may consume too much memory under write-heavy workload or catching up replication when node restarts.

I think we can abstracts a cache interface and provide a multi-generation cache to replace current one:

  • Gen-1: totaly in memory with limited capacity.
  • Gen-2: Off-heap cache.When Gen-1 overflows, move the LRU(least recently used) item into off-heap cache such as OHC.

Main goals:

  • Abstracts log cache interface.
  • Provide a multi-generation cache implementation.

贡献者指南