Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

TreeReader trait: key ranges are not efficiently iterable. #81

Open
preston-evans98 opened this issue Feb 24, 2023 · 0 comments
Open

TreeReader trait: key ranges are not efficiently iterable. #81

preston-evans98 opened this issue Feb 24, 2023 · 0 comments
Assignees

Comments

@preston-evans98
Copy link
Collaborator

preston-evans98 commented Feb 24, 2023

Background

The TreeReader trait defines the method get_value_opt(max_version: Version, key_hash: KeyHash) -> Result<Option<OwnedValue>>. This method supports the get and get_with_proof methods of the JMT.

To satisfy this interface, an underlying RocksDB implementation has several options:

Map (Version, KeyHash) to Value

The simplest option is to store a mapping from (Version, KeyHash) to Value. This approach allows efficient writes with low compaction overhead, since items are naturally sorted by version. However, it has very poor read efficiency. To satisfy a get_value_opt query, the DB has to iterate backwards over all versions until the key_hash is found. To avoid iteration on get queries, the DB implementation needs to store a second table mapping KeyHashes to Versions. Since this table will be written in random order, it will have high compaction.

In addition, a DB with this setup can't support queries on (unhashed) keys without an adding an extra table to track which keys are present. And even with this additional table, range queries on raw keys are extremely inefficient - since the hash for each key is random.

Map (Key, Version) to Value

A second potential database layout is to store a mapping from (Key, Version) to Value. This schema has the drawback that writes happen in un-sorted order, which adds significant compaction overhead. But, it supports very efficient range queries on keys, and it allows easy retrieval of the history for a given key. So, for read-heavy workloads, this layout is much more efficient.

However, the current TreeReader interface requires apps which pick this layout to add an additional table mapping KeyHashes back to raw Keys.

Potential Change

We should consider changing the TreeReader (and the get, get_with_proof methods) to work on Keys rather than KeyHashes. This would enable implementers to pick either database layout with no extra overhead.

@zbuc zbuc added this to Testnets Mar 31, 2023
@zbuc zbuc moved this to Future in Testnets Mar 31, 2023
@erwanor erwanor self-assigned this Apr 8, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
No open projects
Status: Future
Development

No branches or pull requests

2 participants