ChunkAttention: Efficient Self-Attention with Prefix-Aware KV Cache and Two-Phase Partition
Lu Ye, Ze Tao, Yong Huang, Yang Li
TL;DR
The paper tackles the self-attention bottleneck in long-context LLM inference by leveraging shared system prompts through a prefix-aware KV cache organized as a prefix tree (PAKV) and a two-phase partition (TPP) kernel. This design enables runtime detection and sharing of KV tensors across requests with common prefixes, reducing memory waste and improving data locality during decoding. Empirical results show 3.2–4.8× kernel speedups and 70–90% KV-cache memory reductions when long prompts are shared, with end-to-end throughput gains of 1.6–2.3× on real models and deployments. The work demonstrates practical, scalable improvements for multi-tenant LLM serving and provides a concrete pathway to faster, memory-efficient self-attention in long-context settings.
Abstract
Self-attention is an essential component of large language models (LLM) but a significant source of inference latency for long sequences. In multi-tenant LLM serving scenarios, the compute and memory operation cost of self-attention can be optimized by using the probability that multiple LLM requests have shared system prompts in prefixes. In this paper, we introduce ChunkAttention, a prefix-aware self-attention module that can detect matching prompt prefixes across multiple requests and share their key/value tensors in memory at runtime to improve the memory utilization of KV cache. This is achieved by breaking monolithic key/value tensors into smaller chunks and structuring them into the auxiliary prefix tree. Consequently, on top of the prefix-tree based KV cache, we design an efficient self-attention kernel, where a two-phase partition algorithm is implemented to improve the data locality during self-attention computation in the presence of shared system prompts. Experiments show that ChunkAttention can speed up the self-attention kernel by 3.2-4.8$\times$ compared to the state-of-the-art implementation, with the length of the system prompt ranging from 1024 to 4096.
