What are you looking for ?
Advertise with us
RAIDON

R&D: TriCache, User-Transparent Block Cache Enabling High-Performance Out-of-Core Processing with In-Memory Programs

Cache mechanism enables in-memory programs to efficiently process out-of-core datasets without requiring any code rewrite.

ACM Transactions on Storage has published an article written by Guanyu Feng, Huanqi Cao, Department of Computer Science and Technology and BNRist Tsinghua University, China, Xiaowei Zhu, Ant Group, China, Bowen Yu, Yuanwei Wang, Zixuan Ma, Shengqi Chen, and Wenguang Chen, Department of Computer Science and Technology and BNRist Tsinghua University, China.

Abstract: Out-of-core systems rely on high-performance cache sub-systems to reduce the number of I/O operations. While the page cache in modern operating systems enables transparent access to memory and storage devices, it suffers from efficiency and scalability issues on cache misses, forcing out-of-core systems to design and implement their own cache components, which is a non-trivial task.“

This study proposes TriCache, a cache mechanism that enables in-memory programs to efficiently process out-of-core datasets without requiring any code rewrite. It provides a virtual memory interface on top of the conventional block interface to simultaneously achieve user transparency and sufficient out-of-core performance. A multi-level block cache design is proposed to address the challenge of per-access address translations required by a memory interface. It can exploit spatial and temporal localities in memory or storage accesses to render storage-to-memory address translation and page-level concurrency control adequately efficient for the virtual-memory interface. Our evaluation shows that in-memory systems operating on top of TriCache can outperform Linux OS page cache by more than one order of magnitude, and can deliver performance comparable to or even better than that of corresponding counterparts designed specifically for out-of-core scenarios.“

Articles_bottom
ExaGrid
AIC
ATTOtarget="_blank"
OPEN-E