Reactive database engine written in Java (17+) using Project Reactor.
This library provides a basic reactive abstraction and implementation of a key-value store and a search engine.
Four implementations exists out-of-the-box, two for the key-value store, two for the search engine, but it's possible to add more implementations.
Queries can be serialized and deserialized using an efficient custom serialization format
The database abstraction can avoid copying the data multiple times by using RocksDB JNI and Netty 5 buffers
A data generator that generates Java 16 records is available: it allows you to generate custom records by defining the fields using a .yaml file.
The generator also generates at compile time the source of specialized serializers, deserializers, and upgraders, for each custom record.
The key-value store abstraction allows you to deserialize old versions of your data transparently, by using the custom upgraders and the custom deserializers automatically.
The data generator can be found in the Data generator repository.
RocksDB key-value store
Apache Lucene Core indexing library
Why is it so difficult to use?
This is not a DBMS.
This is an engine on which a DBMS can be built upon; for this reason it's very difficult to use directly without building another abstraction layer on top.
Can I use objects instead of byte arrays?
Yes, you must serialize/deserialize them using a library of your choice.
CodecSerializer allows you to implement versioned data using a codec for each data version. Note that it uses 1 to 4 bytes more for each value to store the version.
Why there is a snapshot function for each database part?
Since RocksDB and lucene indices are different libraries, you can't take a snapshot of every database atomically.
An universal snapshot must be implemented as a collection of each database snapshot.
Is CavalliumDB Engine suitable for your project?
No.
This engine is largely undocumented, and it doesn't provide extensive tests.
In src/example/java
you can find some (ugly) examples.