Skip to content

dhoard/tidesdb-java

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

27 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

tidesdb-java

tidesdb-java is the official Java binding for TidesDB.

TidesDB is a fast and efficient key-value storage engine library written in C. The underlying data structure is based on a log-structured merge-tree (LSM-tree). This Java binding provides a safe, idiomatic Java interface to TidesDB with full support for all features.

Features

  • MVCC with five isolation levels from READ UNCOMMITTED to SERIALIZABLE
  • Column families (isolated key-value stores with independent configuration)
  • Bidirectional iterators with forward/backward traversal and seek support
  • TTL (time to live) support with automatic key expiration
  • LZ4, LZ4 Fast, ZSTD, Snappy, or no compression
  • Bloom filters with configurable false positive rates
  • Global block CLOCK cache for hot blocks
  • Savepoints for partial transaction rollback
  • Six built-in comparators plus custom registration

For Java usage you can go to the TidesDB Java Reference here.

License

Multiple licenses apply:

  • Mozilla Public License Version 2.0 (TidesDB)
  • BSD 3-Clause (Snappy)
  • BSD 2-Clause (LZ4)
  • BSD 2-Clause (xxHash - Yann Collet)
  • BSD (Zstandard)

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

Support

About

Official Java binding for TidesDB

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors

Languages

  • Java 71.0%
  • C 26.4%
  • CMake 1.8%
  • Other 0.8%