BoJack is a single-node key-value store written in Crystal, largely inspired by Redis.
- Source Code
- https://github.com/marceloboeira/bojack[01]
- Developer
- Country of Origin
- DE
- Start Year
- 2016 [07]
- End Year
- 2018
- Project Type
- Open Source
- Written in
- Crystal
- Inspired By
- Redis
- Operating System
- Linux
- License
- MIT License
BoJack is a single-node key-value store written in Crystal, largely inspired by Redis.
History[02]
This DBMS was started by Marcelo Boeira in 2016 as a learning vehicle for understanding the development of NoSQL database systems, such as Redis. Originally written for Crystal, it has since been built out to additionally support Python, Ruby, and Elixir with help from Mauricio Antunes, Hugo Abonizio, and Vitalii Elenhaupt. Its last commit was made in early 2018, and Boeira has since archived the Github repository.
Concurrency Control[03]
BoJack does not provide any kind of concurrency control. Concurrent client requests are handled by the Crystal language's concurrent Channel class, which is an abstraction of threads.
Data Model[01]
BoJack's data model relies on a key/value store which maps string keys to string array values.
Logging[04]
Bojack logs, in addition to errors, individual commands for any client action, along with the date and time of interaction, and the client's address and port.
This includes anytime a client connects, or a key is set, updated, or deleted.
Query Interface[05]
Bojack provides a standard command-line interface for starting the server and connecting clients.
Storage Model[06]
BoJack uses Crystal's default in-memory hash table to store its data as key-value pairs.
Citations
7 sources- GitHub - marceloboeira/bojack: 🐴 The unreliable key-value store · GitHub github.com
- https://medium.com/@marceloboeira/why-you-should-build-your-own-nosql-database-9bbba42039f5 medium.com
- Channel::Unbuffered(T) - github.com/crystal-lang/crystal crystal-lang.org
- bojack/src/bojack/logger.cr at master · marceloboeira/bojack · GitHub github.com
- GitHub - marceloboeira/bojack: 🐴 The unreliable key-value store · GitHub github.com
- bojack/src/bojack/memory.cr at master · marceloboeira/bojack · GitHub github.com
- chore: Bootstrap BoJack :horse: github.com