Skip to main content

A serverless embedded streaming OLAP data pipeline

Project description

hypersync-lancedb-pipe

A serverless embedded streaming OLAP data pipeline that leverages historical blockchain data from Hypersync and mutable columnar storage format lance.

Since Lance is designed to be mutable, it is possible to create an embedded streaming pipeline using the same data source. The main advantage of this streaming approach is that it doesn't require any parquet glob file management. This reduces the complexity of streaming to the same as batch processing. The other main benefit is that LanceDB has tight integration with both polars and duckdb. LanceDB accepts polars dataframes as data inputs, which allows for a more flexible ETL pipeline, allowing polars to be used as a preprocessing tool.

Since LanceDB leverages the Apache Arrow Standard, there is a lot of flexibility to query from ths database - such as querying larger than memory datasets with polars lazyframes and a dataframe API, or using an embedded OLAP engine like duckdb for faster speed and SQL API.

Getting Started

  1. This repository uses rye to manage dependencies and the virtual environment. To install, refer to this link for instructions here.
  2. Once rye is installed, run rye sync to install dependencies and setup the virtual environment, which has a default name of .venv.
  3. Activate the virtual environment with the command source .venv/bin/activate.

Running the Pipeline

There are some script examples in the scripts folder. These examples demonstrate the versatility of the lancedb writer.

  • Run historical_sync.py file to backfill data from a historical block number. Assumes there is no existing table.
  • Run head_sync.py to sync the database to the head of the chain. Assumes existing table exists.
  • Run backfill_sync.py to perform a backfill sync from the earliest block number. Assumes existing table exists.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

hypersync_lancedb_pipe-0.1.1.tar.gz (7.7 kB view details)

Uploaded Source

Built Distribution

hypersync_lancedb_pipe-0.1.1-py3-none-any.whl (3.2 kB view details)

Uploaded Python 3

File details

Details for the file hypersync_lancedb_pipe-0.1.1.tar.gz.

File metadata

File hashes

Hashes for hypersync_lancedb_pipe-0.1.1.tar.gz
Algorithm Hash digest
SHA256 39d00c88e6b73c246765b5903592da645d6f84ddfef8df26cc03b8194a4f896f
MD5 a63222d499f07e53a6d3f328f867ceac
BLAKE2b-256 44bfbbd4396e35e053d714320d6828da2b7a0e906592a88b0521d06d61f2517e

See more details on using hashes here.

File details

Details for the file hypersync_lancedb_pipe-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for hypersync_lancedb_pipe-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 2260e9e898f707cc1796ffb473bafb2e60af2179ed4f5697f01c6758b8ce0b23
MD5 252062c5e9c2d64591211005572f671c
BLAKE2b-256 f0f6548d7886062ab9baee141476dcb603a12ba5fe6ff037345c69c9695c2e80

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page