DarkBird is a Document oriented, concurrency, in-memory Storage, highly optimized for retrieve document very fast with indexing and taging feature also persist data to disk to avoid loss any data
The darkbird provides the following:
Persistent - use Non-Blocking write-ahead-logging engine for persistency data, also store data to multiple pages with totalpagesize
In-memory - whole data stored in-memory with two mode ( DiskCopies , RamCopies ) both stored in-memory but DiskCopies persistent data to disk and after restart, darkbird load whole data to memory
Concurrency - darkbird use one of best high-concurrent HashMap (DashMap)[https://github.com/xacrimon/conc-map-bench] and you don't need use Mutex/RwLock for sync between thread, storage is complete safe to shared between thread
Indexing - darkbird support indexing, can even dynamically decision about which fields in document be indexed. and each key must be unique unless return Duplicate error
Taging - each document can have multiple tags And one tag can refer to many documents The tag is great for indexing groups of documents To retrieve very quickly by one key. For example Players of a club, Developers of a company, etc
Migration - darkbird storage model is (Key, Document)
if you want change Document Model, can use migration::run
for change all (Key, Document) already exist in disk
this module should be use before storage opened
copy/load to external database - copy storage to (postgres/cassandra/scylla) and load from that
Event Handling - can subscribe any channel you want to storage, they
get storage event (RQuery<Key, Document>, Subscribed(tokio::mpsc::Sender(Event<key, document>))
)
Improve Performance
Persistent Copy whole data to Database and load from that
Document model must implement three trait from this vsn
Indexing
Taging
Range range is like indexing but each key can ref to many documents also can do range query over indexes to retrieve document.
The complete Examples on Link.
darkbird = "2.0.0"