Go to file
2019-03-12 23:56:57 +10:00
cmd/bitcask Initial Commit 2019-03-12 23:56:57 +10:00
proto Initial Commit 2019-03-12 23:56:57 +10:00
streampb Initial Commit 2019-03-12 23:56:57 +10:00
tools Initial Commit 2019-03-12 23:56:57 +10:00
.drone.yml Initial Commit 2019-03-12 23:56:57 +10:00
.gitignore Initial Commit 2019-03-12 23:56:57 +10:00
.goreleaser.yml Initial Commit 2019-03-12 23:56:57 +10:00
bitcask_test.go Initial Commit 2019-03-12 23:56:57 +10:00
bitcask.go Initial Commit 2019-03-12 23:56:57 +10:00
datafile.go Initial Commit 2019-03-12 23:56:57 +10:00
entry.go Initial Commit 2019-03-12 23:56:57 +10:00
go.mod Initial Commit 2019-03-12 23:56:57 +10:00
go.sum Initial Commit 2019-03-12 23:56:57 +10:00
keydir.go Initial Commit 2019-03-12 23:56:57 +10:00
Makefile Initial Commit 2019-03-12 23:56:57 +10:00
README.md Initial Commit 2019-03-12 23:56:57 +10:00
version_test.go Initial Commit 2019-03-12 23:56:57 +10:00
version.go Initial Commit 2019-03-12 23:56:57 +10:00

bitcask

Build Status CodeCov Go Report Card GoDoc Sourcegraph

A Bitcask (LSM+WAL) Key/Value Store written in Go.

Features

  • Embeddable
  • Builtin CLI

Install

$ go get github.com/prologic/bitcask

Usage (library)

Install the package into your project:

$ go get github.com/prologic/bitcask
package main

import (
    "log"

    "github.com/prologic/bitcask"
)

func main() {
    db, _ := bitcask.Open("/tmp/db")
    db.Set("Hello", []byte("World"))
    db.Close()
}

See the godoc for further documentation and other examples.

Usage (tool)

$ bitcask -p /tmp/db set Hello World
$ bitcask -p /tmp/db get Hello
World

Performance

Benchmarks run on a 11" Macbook with a 1.4Ghz Intel Core i7:

$ make bench
...
BenchmarkGet-4   	   50000	     33185 ns/op	     600 B/op	      14 allocs/op
BenchmarkPut-4   	  100000	     16757 ns/op	     699 B/op	       7 allocs/op
  • ~30,000 reads/sec
  • ~60,000 writes/sec

License

bitcask is licensed under the MIT License