Skytable is a modern scalable NoSQL database with BlueQL, designed for performance, scalability and flexibility. Skytable gives you spaces, models, data types, complex collections and more to build powerful experiences
You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
Sayan 597a82ddf0
Use binary for building docker image (#40)
* Use binary for building docker image

In the previous workflow, we were building and testing twice: once for
the docker image and once for the test step. Now, we'll build a debug
version in the test step, then build a release version and finally copy
that into the docker image. This would heavily reduce our build times.

* Ignore specific files in target to speed up builds

* Build image only when pushed to next or tagged

* Fix build condition

Since both conditions have to evaluate to true, we'll need to use refs
while also matching against both `push` and `tag` events

Signed-off-by: Sayan Nandan <nandansayan@outlook.com>
4 years ago
.github Stop using ubuntu image to reduce build times 4 years ago
ci Don't checkout `next` while setting variables 4 years ago
cli Rollout 0.5.0 4 years ago
examples/config-files Don't use an explicit `enabled` flag in `snapshot` 4 years ago
libtdb Rollout 0.5.0 4 years ago
server Rollout 0.5.0 4 years ago
tdb-bench Rollout 0.5.0 4 years ago
tdb-macros Revise random port allocation logic 4 years ago
.ci.yml Use binary for building docker image (#40) 4 years ago
.dockerignore Use binary for building docker image (#40) 4 years ago
.gitignore Re-implement snapshots and add tests 4 years ago
AUTHORS.md Updated project metadata 4 years ago
CHANGELOG.md Rollout 0.5.0 4 years ago
CLA.md Improve community documentation 4 years ago
CODE_OF_CONDUCT.md Improve community documentation 4 years ago
CONTRIBUTING.md Make MKSNAP return code 3 for `howmany != 0` 4 years ago
CONTRIBUTORS.md Improve docs 4 years ago
Cargo.lock Rollout 0.5.0 4 years ago
Cargo.toml Remove `testsuite` crate and decompose a few tests 4 years ago
Dockerfile Use binary for building docker image (#40) 4 years ago
LICENSE Formal terrapipe query parsing 4 years ago
README.md Fix issues with the Dockerfile 4 years ago
actions.jsonc Use refs instead of cloning for pre-compiled resps 4 years ago
pushrelease.sh Improve workflow and docs 4 years ago
release.sh Add diskstore module 4 years ago

README.md

<html>

TerrabaseDB

The next-generation NoSQL database

GitHub Workflow Status Status: Alpha Development GitHub release (latest SemVer including pre-releases) GitHub commit activity

Docker Pulls Docs Contribute Now

</html>

What is TerrabaseDB?

TerrabaseDB (or TDB for short) is an effort to provide the best of key/value stores, document stores and columnar databases, that is, simplicity, flexibility and queryability at scale. TDB is curently in an alpha stage, but can be used as a performant and persistent key-value store.

Getting started 🚀

  1. Download a bundle for your platform from here ⬇️
  2. Unzip the bundle
  3. Make the files executable (run chmod +x tdb tsh on *nix systems)
  4. First run tdb to start the database server and then run tsh to start the interactive shell
  5. Run commands like: SET foo bar , GET bar , UPDATE cat mitten or DEL proprietary 🤪 on tsh !

Features

  • Insanely fast: Scale to millions of queries per second per node
  • Key/value store: GET , SET , UPDATE and all that stuff
  • Snapshots: Automated (and tunable) snapshots for stress-free backups
  • Multithreaded: Designed to exploit all CPU cores
  • Resource friendly: The database server doesn't need more than 1MB to run
  • Convenient: Without the setup hassle and system-specific dependencies

(... and more on the way)

Clients 🔌

Until we release an official driver, you'll have to write your own clients — all you need to do is implement the simple and performant Terrapipe protocol spec.

Community 👐

A project which is powered by the community believes in the power of community! If you get stuck anywhere - here are your options!

<html> </html>

Platforms 💻

Linux supported macOS supported Windows supported

Versioning

This project strictly follows semver, however, since this project is currently in the development phase (0.x.y), the API may change unpredictably

Contributing

Contribute Now

Yes - we need you! Be it a typo, a bizarre idea, a dirty bug🐞 or an amazing patch - you're welcome to contribute to TDB! Beginner friendly issues are marked with the label. Read the guide here.

Contributors

You can see a full list of contributors here

License

This project is licensed under the AGPL-3.0 License.