1
0
mirror of https://github.com/nxshock/zkv.git synced 2025-01-17 19:11:10 +05:00
nxshock 5f0d33828f Improve store read speed
by skipping store blocks
2022-12-11 21:00:36 +05:00
2022-02-16 16:08:20 +05:00
2022-02-16 16:08:20 +05:00
2022-12-11 21:00:36 +05:00
2022-12-02 20:32:09 +05:00
2022-12-02 20:32:09 +05:00
2022-12-02 20:32:09 +05:00
2022-02-16 16:08:20 +05:00
2022-12-11 21:00:36 +05:00
2022-12-10 22:00:42 +05:00
2022-12-05 21:26:54 +05:00
2022-12-02 21:37:34 +05:00
2022-12-11 21:00:36 +05:00
2022-12-11 21:00:36 +05:00

zkv

Simple key-value store for single-user applications.

Pros

  • Simple one file structure
  • Internal Zstandard compression by klauspost/compress/zstd
  • Threadsafe operations through sync.RWMutex

Cons

  • Index stored in memory (map[key hash (28 bytes)]file offset (int64))
  • Need to read the whole file on store open to create file index (you can use index file options to avoid this)
  • No way to recover disk space from deleted records
  • Write/Delete operations block Read and each other operations
  • Need to decode whole file until stored value

Usage

Create or open existing file:

db, err := zkv.Open("path to file")

Data operations:

// Write data
err = db.Set(key, value) // key and value can be any of type

// Read data
var value ValueType
err = db.Get(key, &value)

// Delete data
err = db.Delete(key)

Other methods:

// Flush data to disk
err = db.Flush()

// Backup data to another file
err = db.Backup("new/file/path")

Store options

type Options struct {
	// Maximum number of concurrent reads
	MaxParallelReads int

	// Compression level
	CompressionLevel zstd.EncoderLevel

	// Memory write buffer size in bytes
	MemoryBufferSize int

	// Disk write buffer size in bytes
	DiskBufferSize int

	// Use index file
	UseIndexFile bool
}

File structure

Record is encoding/gob structure:

Field Description Size
Type Record type uint8
KeyHash Key hash 28 bytes
ValueBytes Value gob-encoded bytes variable

File is log stuctured list of commands:

Field Description Size
Length Record body bytes length int64
Body Gob-encoded record variable

Resource consumption

Store requirements:

  • around 300 Mb of RAM per 1 million of keys
  • around 34 Mb of disk space for index file per 1 million of keys

TODO

  • Add recovery previous state of store file on write error
  • Add fast file seek to value (add compressed block start position)
Description
No description provided
Readme MIT 113 KiB
Languages
Go 100%