Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sintef/rusty-chunkenc
A Rust implementation of Prometheus' chunkenc library
https://github.com/sintef/rusty-chunkenc
chunkenc gorilla parsing prometheus rust-crate serialization time-series
Last synced: about 2 months ago
JSON representation
A Rust implementation of Prometheus' chunkenc library
- Host: GitHub
- URL: https://github.com/sintef/rusty-chunkenc
- Owner: SINTEF
- License: apache-2.0
- Created: 2024-09-13T14:13:43.000Z (4 months ago)
- Default Branch: main
- Last Pushed: 2024-09-25T10:20:21.000Z (3 months ago)
- Last Synced: 2024-09-30T11:49:17.401Z (3 months ago)
- Topics: chunkenc, gorilla, parsing, prometheus, rust-crate, serialization, time-series
- Language: Rust
- Homepage:
- Size: 2.1 MB
- Stars: 0
- Watchers: 4
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# rusty-chunkenc
[![Crates.io](https://img.shields.io/crates/v/rusty-chunkenc.svg)]()
[![Documentation](https://docs.rs/rusty-chunkenc/badge.svg)](https://docs.rs/rusty-chunkenc)
[![License](https://img.shields.io/badge/license-Apache--2.0-blue.svg)](LICENSE)A Rust implementation of Prometheus' [`chunkenc`](https://pkg.go.dev/github.com/prometheus/prometheus/tsdb/chunkenc) library.
## Features
- Parse Prometheus XOR-encoded chunks (that are heavily inspired by [Gorilla](https://www.vldb.org/pvldb/vol8/p1816-teller.pdf)).
- Serialise time series to Prometheus XOR-encoded chunks.
- Read Prometheus' cold data directly from the disk.
- Also comes with utilities to read and write `varint`, `uvarint`, `varbit`, `varbit_ts`, and `varbit_xor` numbers.## Why?
Prometheus uses XOR Chunks in its remote read API, and I wanted to understand how they work in detail. This crate enables [SensApp](https://github.com/sintef/sensapp) to stream data to Prometheus. SensApp is written in Rust, and I wanted a chunkenc Rust implementation.
Also, writing a parser and a serialiser did sound fun.
## License
Apache 2.0. Check the `LICENSE` file for more details.
## Contributing
Feel free to report issues, contribute, or ask questions about this project.
## Acknowledgements
This project is ported from Prometheus' [`chunkenc`](https://pkg.go.dev/github.com/prometheus/prometheus/tsdb/chunkenc), that used [`go-tzs`](https://github.com/dgryski/go-tsz), that is based on the [Gorilla](https://www.vldb.org/pvldb/vol8/p1816-teller.pdf) paper. The parsing heavily relies on [`nom`](https://crates.io/crates/nom).
The project supports the [Smart Building Hub](https://smartbuildinghub.no/) research infrastructure project, which is funded by the [Norwegian Research Council](https://www.forskningsradet.no/).