Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/thomasjungblut/go-sstables
Go library for protobuf compatible sstables, a skiplist, a recordio format and other database building blocks like a write-ahead log. Ships now with an embedded key-value store.
https://github.com/thomasjungblut/go-sstables
compaction database embedded-database hacktoberfest kaitai kaitai-struct key-value-store memstore merge protobuf recordio skiplist sst sstable sstables write-ahead-log
Last synced: 2 days ago
JSON representation
Go library for protobuf compatible sstables, a skiplist, a recordio format and other database building blocks like a write-ahead log. Ships now with an embedded key-value store.
- Host: GitHub
- URL: https://github.com/thomasjungblut/go-sstables
- Owner: thomasjungblut
- License: apache-2.0
- Created: 2018-03-13T17:43:33.000Z (almost 7 years ago)
- Default Branch: main
- Last Pushed: 2025-02-10T16:27:50.000Z (11 days ago)
- Last Synced: 2025-02-12T08:06:48.808Z (9 days ago)
- Topics: compaction, database, embedded-database, hacktoberfest, kaitai, kaitai-struct, key-value-store, memstore, merge, protobuf, recordio, skiplist, sst, sstable, sstables, write-ahead-log
- Language: Go
- Homepage: https://blog.thomasjungblut.com/
- Size: 3.71 MB
- Stars: 280
- Watchers: 5
- Forks: 12
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
[data:image/s3,"s3://crabby-images/697d0/697d0b4ed7bc9ba135313720a77a6d933d4766d4" alt="unit-test"](https://github.com/thomasjungblut/go-sstables/actions/workflows/unit-test.yml)
[data:image/s3,"s3://crabby-images/1ed8b/1ed8b3fa57736aaee9e648650cd7bb5c1de81151" alt="CodeQL"](https://github.com/thomasjungblut/go-sstables/actions/workflows/codeql-analysis.yml)
[data:image/s3,"s3://crabby-images/ef00f/ef00f9a02bf331f27a477ff893c5e0bbd3dc2fe2" alt="Go Reference"](https://pkg.go.dev/github.com/thomasjungblut/go-sstables)## go-sstables
`go-sstables` is a Go library that contains NoSQL database building blocks like a sequential record format (recordio), a
sorted string table (sstable), a write-ahead-log (WAL), and a memory store (memstore) that stores key/value pairs in
memory using a skip list.You can frequently find those in embedded key-value stores or databases as well, notable examples
are [RocksDB](https://github.com/facebook/rocksdb) or [LevelDB](https://github.com/google/leveldb).There is an example embedded key-value database in this library, you can find it in the simpledb folder - please don't
use it for any production workload.While plain `[]byte` are at the core of this library, there are wrappers and bindings for protobuf to enable more
convenient serialization.## Installation
This is a library as it does not contain any installable binary, which means you can just directly add it to your
dependency via `go get`:> go get -d github.com/thomasjungblut/go-sstables
## Documentation
[RocksDB has a great overview](https://github.com/facebook/rocksdb/wiki/RocksDB-Overview#3-high-level-architecture) of
how the components usually play together to get an idea:data:image/s3,"s3://crabby-images/4c5c1/4c5c112bea5aad0508411032cd2feeb2ef7f6779" alt="rocksdb architecture overview"
You will find basically all of those mentioned pieces above and all of them stitched together as SimpleDB. The
documentation is now separated by package for easier browsing, each of those READMEs contain examples - there is
also [/examples](_examples) when you prefer browsing the code directly.* [RecordIO](recordio/README.md)
* [Benchmark](benchmark/README.md#recordio)
* [sstables](sstables/README.md)
* [Benchmark](benchmark/README.md#sstable)
* [Memstore](memstore/README.md)
* [SkipList](skiplist/README.md)
* [WriteAheadLog](wal/README.md)
* [SimpleDB](simpledb/README.md)
* [Benchmark](benchmark/README.md#simpledb)You can also find all interface and
method [documentation on `pkg.go.dev`](https://pkg.go.dev/github.com/thomasjungblut/go-sstables/sstables#section-documentation)
.## Kaitai Support
As you might want to read the data and files in other languages, I've added support for [Kaitai](https://kaitai.io/).
Kaitai is a declarative schema file to define a binary format. From that `ksy` file you can generate code for a lot of
other languages and read the data.Currently, there is support for:
* [RecordIO (v2)](kaitai/recordio_v2.ksy)
You can find more information on how to generate Kaitai readers in [kaitai/README.md](kaitai/README.md).
## Development on go-sstables
### Updating dependencies through Go Modules
[General overview of modules](https://github.com/golang/go/wiki/Modules)
One can update dependencies via:
```
go get -u
```### Generating protobufs
This needs some pre-requisites installed, namely
the [protobuf compiler](https://github.com/protocolbuffers/protobuf/releases) and the go generator plugin. The latter
can be installed as a go package:```
go install google.golang.org/protobuf/cmd/protoc-gen-go
```Full installation details can be found in
the [protobuf dev documentation](https://developers.google.com/protocol-buffers/docs/gotutorial#compiling-your-protocol-buffers)
.Once installed, one can generate the protobuf structs using:
```
make compile-proto
```### Releasing the Go Module
[General Guidance](https://github.com/golang/go/wiki/Modules#releasing-modules-all-versions)
In short, run these commands:
```
make unit-test
make release
git push --tags
```