Storage

This section covers all things related to the on-disk storage of data within Cuprate.

Overview

The quick overview is that Cuprate has a database abstraction crate that handles "low-level" database details such as key and value (de)serialization, tables, transactions, etc.

This database abstraction crate is then used by all crates that need on-disk storage, i.e. the

Service

The interface provided by all crates building on-top of the database abstraction is a tower::Service, i.e. database requests/responses are sent/received asynchronously.

As the interface details are similar across crates (threadpool, read operations, write operations), the interface itself is abstracted in the cuprate_database_service crate, which is then used by the crates.

Diagram

This is roughly how database crates are set up.

                                                           ┌─────────────────┐
┌──────────────────────────────────┐                       │                 │
│ Some crate that needs a database │  ┌────────────────┐   │                 │
│                                  │  │     Public     │   │                 │
│ ┌──────────────────────────────┐ │─►│ tower::Service │◄─►│ Rest of Cuprate │
│ │     Database abstraction     │ │  │      API       │   │                 │
│ └──────────────────────────────┘ │  └────────────────┘   │                 │
└──────────────────────────────────┘                       │                 │
                                                           └─────────────────┘
Last change: 2024-11-28, commit: 38541db