A JSON document-based database that relies on key based access to achieve O(1) access time.
smolDB
is a document database with key-based access and reference resolution, all documents are on-disk, human-readable, and can be accessed through a REST API, making them very easy for debugging.
However, the database does not support any advanced queries, sharding, or support for storage distribution.
Get started quickly with the API via docker:
docker run -p 8080:8080 nishank02/smoldb:latest
- Quick access — key-based retrieval in O(1) time
- Simple to troubleshoot — all documents are stored as human-readable JSON files
- Easy to deploy — a single executable with no external dependencies no need for language-specific drivers!
# check the heath of the database
curl localhost:8080/
# example output on 200 OK
# > {"message":["smolDB is working fine!"]}
# get all files in database index
curl localhost:8080/keys
# example output on 200 OK
# > {"files":["test","test2","test3"]}
# manually regenerate index
# shouldn't need to be done as each operation should update index on its own
curl -X POST localhost:8080/regenerate
# example output on 200 OK
# > regenerated index
# get document with key `test`
curl localhost:8080/key/test
# example output on 200 OK (found key)
# > {"example_field": "example_value"}
# example output on 404 NotFound (key not found)
# > key 'test' not found
# creates document `test` if it doesn't exist
# otherwise, replaces content of `key` with given
curl -X PUT -H "Content-Type: application/json" \
-d '{"key1":"value"}' localhost:8080/key/test
# example output on 200 OK (create/update success)
# > create 'test' successful
# deletes document `test`
curl -X DELETE localhost:8080/key/test
# example output on 200 OK (delete success)
# > delete 'test' successful
# example output on 404 NotFound (key not found)
# > key 'test' doest not exist
# get `example_field` of document `test`
curl localhost:8080/key/test/field/example_field
# example output on 200 OK (found field)
# > "example_value"
# example output on 400 BadRequest (field not found)
# > err key 'test' does not have field 'example_field'
# example output on 404 NotFound (key not found)
# > key 'test' not found
# update `field` of document `test` with content
# if field doesnt exist, create it
curl -X PATCH -H "Content-Type: application/json" \
-d '{"nested":"json!"}' \
localhost:8080/key/test/field/example_field
# example output on 200 OK (found field)
# > patch field 'example_field' of key 'key' successful
# example output on 404 NotFound (key not found)
# > key 'test' not found
smoldb help # shows a list of commands
smoldb start # start a smoldb server on :8080 using folder `db`
smoldb shell # start an interactive smoldb shell
This command starts a new smoldb
server which listens for requests port :8080
and uses the default folder db
.
You can change the directory with the --dir <value>, -d <value>
flag.
# e.g.
smoldb --dir some/folder start # start a smoldb server using folder `some/folder`
smoldb -d . start # start a smoldb shell in the current directory
You can also change the port the server is hosted on with the --p <value>, -p <value>
flag.
# e.g.
smoldb start --port 8081 # start a smoldb server on port 8081
smoldb -d . start -p 8080 # start a smoldb server on port 8080 using current directory
This command starts a new smoldb
interactive shell using the defailt folder db
.
The interactive shell is more like a quick tool to explore the database by allowing easy viewing of the database index, lookup of documents, and deletion of documents.
Similar to the smoldb
server, you can change the directory with the --dir <value>, -d <value>
flag.
# e.g.
smoldb -d . shell # start a smoldb shell using current directory
You can refer to other documents by using a reference of the form REF::<key>
. For example, with the following two JSONs:
{
"key": "REF::nested"
}
{
"nestedKey": "nestedVal"
}
You end up with the following:
{
"key": {
"nestedKey": "nestedVal"
}
}
- Run
git clone https://github.com/themillenniumfalcon/smolDB
- Run
make build
- For cross-platform builds, run
make build-all
(optional)