brk_indexer 0.0.0

A Bitcoin Core indexer built on top of brk_parser
Documentation

Indexer

A Bitcoin Core node indexer which iterates over the chain (via ../iterator) and creates a database of the vecs (../storable_vec) and key/value stores (fjall) that can be used in your Rust code.

The crate only stores the bare minimum to be self sufficient and not have to use an RPC client (except for scripts which are not stored). If you need more data, checkout ../computer which uses the outputs from the indexer to compute a whole range of datasets.

Vecs are used sparingly instead of stores for multiple reasons:

  • Only stores the relevant data since the key is an index
  • Saved as uncompressed bytes and thus can be parsed manually (with any programming language) without relying on a server or library
  • Easy to work with and predictable

Usage

Storage wise, the expected overhead should be around 30% of the chain itself.

Peaks at 11-13 GB of RAM

Outputs

Vecs: src/storage/storable_vecs/mod.rs

Stores: src/storage/fjalls/mod.rs

Examples

Rust: src/main.rs

Python: ../python/parse.py