Algorithmic Complexity Attacks on Dynamic Learned Indexes
Proceedings of the VLDB Endowment(2024)
摘要
Learned Index Structures (LIS) view a sorted index as a model that learns the
data distribution, takes a data element key as input, and outputs the predicted
position of the key. The original LIS can only handle lookup operations with no
support for updates, rendering it impractical to use for typical workloads. To
address this limitation, recent studies have focused on designing efficient
dynamic learned indexes. ALEX, as the pioneering dynamic learned index
structures, enables dynamism by incorporating a series of design choices,
including adaptive key space partitioning, dynamic model retraining, and
sophisticated engineering and policies that prioritize read/write performance.
While these design choices offer improved average-case performance, the
emphasis on flexibility and performance increases the attack surface by
allowing adversarial behaviors that maximize ALEX's memory space and time
complexity in worst-case scenarios. In this work, we present the first
systematic investigation of algorithmic complexity attacks (ACAs) targeting the
worst-case scenarios of ALEX. We introduce new ACAs that fall into two
categories, space ACAs and time ACAs, which target the memory space and time
complexity, respectively. First, our space ACA on data nodes exploits ALEX's
gapped array layout and uses Multiple-Choice Knapsack (MCK) to generate an
optimal adversarial insertion plan for maximizing the memory consumption at the
data node level. Second, our space ACA on internal nodes exploits ALEX's
catastrophic cost mitigation mechanism, causing an out-of-memory error with
only a few hundred adversarial insertions. Third, our time ACA generates
pathological insertions to increase the disparity between the actual key
distribution and the linear models of data nodes, deteriorating the runtime
performance by up to 1,641X compared to ALEX operating under legitimate
workloads.
更多查看译文
AI 理解论文
溯源树
样例
生成溯源树,研究论文发展脉络
Chat Paper
正在生成论文摘要