NACL: A General and Effective KV Cache Eviction Framework for LLMs at Inference Time
Yilong Chen, Guoxia Wang, Junyuan Shang, Shiyao Cui, Zhenyu Zhang, Tingwen Liu, Shuohuan Wang, Yu Sun, Dianhai Yu, Hua Wu
TL;DR
NaCl addresses the costly memory footprint of KV caches in LLM inference with long contexts by introducing an encoding-phase, one-shot eviction framework that couples Proxy-Tokens Eviction with Random Eviction. By leveraging global attention statistics from a small set of proxy tokens and adding diversified randomness, NaCl reduces KV-cache usage up to 50% while preserving more than 95% of performance across short- and long-text tasks. The method achieves these gains with a simple, training-free design compatible with FlashAttention-2, and demonstrates strong robustness through extensive ablations on LLaMA2-7B variants and LongBench tasks. This work enables more efficient, scalable long-context inference and provides a practical path toward memory-efficient deployment of large language models.
Abstract
Large Language Models (LLMs) have ignited an innovative surge of AI applications, marking a new era of exciting possibilities equipped with extended context windows. However, hosting these models is cost-prohibitive mainly due to the extensive memory consumption of KV Cache involving long-context modeling. Despite several works proposing to evict unnecessary tokens from the KV Cache, most of them rely on the biased local statistics of accumulated attention scores and report performance using unconvincing metric like perplexity on inadequate short-text evaluation. In this paper, we propose NACL, a general framework for long-context KV cache eviction that achieves more optimal and efficient eviction in a single operation during the encoding phase. Due to NACL's efficiency, we combine more accurate attention score statistics in PROXY TOKENS EVICTION with the diversified random eviction strategy of RANDOM EVICTION, aiming to alleviate the issue of attention bias and enhance the robustness in maintaining pivotal tokens for long-context modeling tasks. Notably, our method significantly improves the performance on short- and long-text tasks by 80% and 76% respectively, reducing KV Cache by up to 50% with over 95% performance maintenance. The code is available at https://github.com/PaddlePaddle/Research/tree/master/NLP/ACL2024-NACL.
