forked from mirror/ledisdb
200 lines
5.4 KiB
Markdown
200 lines
5.4 KiB
Markdown
# LedisDB
|
|
|
|
[![Build Status](https://travis-ci.org/ledisdb/ledisdb.svg?branch=develop)](https://travis-ci.org/ledisdb/ledisdb) [![codecov](https://codecov.io/gh/ledisdb/ledisdb/branch/master/graph/badge.svg)](https://codecov.io/gh/ledisdb/ledisdb) [![goreportcard](https://goreportcard.com/badge/git.internal/re/ledisdb)](https://goreportcard.com/report/git.internal/re/ledisdb)
|
|
|
|
Ledisdb is a high-performance NoSQL database library and server written in [Go](http://golang.org). It's similar to Redis but store data in disk. It supports many data structures including kv, list, hash, zset, set.
|
|
|
|
LedisDB now supports multiple different databases as backends.
|
|
|
|
## Features
|
|
|
|
+ Rich data structure: KV, List, Hash, ZSet, Set.
|
|
+ Data storage is not limited by RAM.
|
|
+ Various backends supported: LevelDB, goleveldb, RocksDB, RAM.
|
|
+ Supports Lua scripting.
|
|
+ Supports expiration and TTL.
|
|
+ Can be managed via redis-cli.
|
|
+ Easy to embed in your own Go application.
|
|
+ HTTP API support, JSON/BSON/msgpack output.
|
|
+ Replication to guarantee data safety.
|
|
+ Supplies tools to load, dump, and repair database.
|
|
+ Supports cluster, use [xcodis](https://github.com/ledisdb/xcodis).
|
|
+ Authentication (though, not via http).
|
|
+ Repair integrated: You can use `ledis repair` to repair broken databases and `ledis repair-ttl` to repair a very serious bug for key expiration and TTL if you upgraded from v0.4.
|
|
|
|
## Build from source
|
|
|
|
Create a workspace and checkout ledisdb source
|
|
|
|
```shell
|
|
git clone git@github.com:ledisdb/ledisdb.git
|
|
cd ledisdb
|
|
|
|
#set build and run environment
|
|
source dev.sh
|
|
|
|
make
|
|
make test
|
|
```
|
|
|
|
Then you will find all the binary build on `./bin` directory.
|
|
|
|
## LevelDB support
|
|
|
|
+ Install leveldb and snappy.
|
|
|
|
LedisDB supplies a simple script to install leveldb and snappy:
|
|
|
|
sudo sh tools/build_leveldb.sh
|
|
|
|
It will install leveldb at /usr/local/leveldb and snappy at /usr/local/snappy by default.
|
|
|
|
LedisDB uses the modified LevelDB for better performance. [Details.](https://git.internal/re/ledisdb/wiki/leveldb-source-modification)
|
|
|
|
You can easily use other LevelDB versions (like Hyper LevelDB or Basho LevelDB) instead, as long as the header files are in `include/leveldb`, not `include/hyperleveldb` or any other location.
|
|
|
|
+ Set `LEVELDB_DIR` and `SNAPPY_DIR` to the actual install path in dev.sh.
|
|
+ `make clean && make`
|
|
|
|
## RocksDB support
|
|
|
|
+ [Install rocksdb(5.1+)](https://github.com/facebook/rocksdb/blob/master/INSTALL.md)(`make shared_lib`) and snappy first.
|
|
|
|
LedisDB has not yet supplied a simple script to install.
|
|
|
|
+ Set `ROCKSDB_DIR` and `SNAPPY_DIR` to the actual install path in `dev.sh`.
|
|
+ `make clean && make`
|
|
|
|
|
|
If the RocksDB API changes, LedisDB may not build successfully. LedisDB currently supports RocksDB version 5.1 or later.
|
|
|
|
## Choose store database
|
|
|
|
LedisDB now supports goleveldb, leveldb, rocksdb, and RAM. It will use goleveldb by default.
|
|
|
|
Choosing a store database to use is very simple.
|
|
|
|
+ Set in server config file
|
|
|
|
db_name = "leveldb"
|
|
|
|
+ Set in command flag
|
|
|
|
ledis -config=/etc/ledis.conf -db_name=leveldb
|
|
|
|
Flag command set will overwrite config setting.
|
|
|
|
## Lua support
|
|
|
|
Lua is supported using [gopher-lua](https://github.com/yuin/gopher-lua), a Lua VM, completely written in Go.
|
|
|
|
## Configuration
|
|
|
|
LedisDB uses [toml](https://github.com/toml-lang/toml) as the configuration format. The basic configuration ```./etc/ledis.conf``` in LedisDB source may help you.
|
|
|
|
If you don't use a configuration, LedisDB will use the default for you.
|
|
|
|
## Server Example
|
|
|
|
```shell
|
|
//set run environment if not
|
|
source dev.sh
|
|
|
|
./bin/ledis -config=/etc/ledis.conf
|
|
|
|
//another shell
|
|
./bin/ledis cli -p 6380
|
|
|
|
ledis 127.0.0.1:6380> set a 1
|
|
OK
|
|
ledis 127.0.0.1:6380> get a
|
|
"1"
|
|
|
|
//use curl
|
|
curl http://127.0.0.1:11181/SET/hello/world
|
|
→ {"SET":[true,"OK"]}
|
|
|
|
curl http://127.0.0.1:11181/0/GET/hello?type=json
|
|
→ {"GET":"world"}
|
|
```
|
|
|
|
|
|
## Package Example
|
|
|
|
```go
|
|
import (
|
|
lediscfg "git.internal/re/ledisdb/config"
|
|
"git.internal/re/ledisdb/ledis"
|
|
)
|
|
|
|
# Use Ledis's default config
|
|
cfg := lediscfg.NewConfigDefault()
|
|
l, _ := ledis.Open(cfg)
|
|
db, _ := l.Select(0)
|
|
|
|
db.Set(key, value)
|
|
|
|
db.Get(key)
|
|
```
|
|
|
|
## Replication Example
|
|
|
|
Set slaveof in config or dynamiclly
|
|
|
|
```shell
|
|
ledis cli -p 6381
|
|
|
|
ledis 127.0.0.1:6381> slaveof 127.0.0.1 6380
|
|
OK
|
|
```
|
|
|
|
## Cluster support
|
|
|
|
LedisDB uses a proxy named [xcodis](https://github.com/ledisdb/xcodis) to support cluster.
|
|
|
|
## CONTRIBUTING
|
|
|
|
See [CONTRIBUTING.md] .
|
|
|
|
## Benchmark
|
|
|
|
See [benchmark](https://git.internal/re/ledisdb/wiki/Benchmark) for more.
|
|
|
|
## Todo
|
|
|
|
See [Issues todo](https://git.internal/re/ledisdb/issues?labels=todo&page=1&state=open)
|
|
|
|
## Client
|
|
|
|
See [Clients](https://git.internal/re/ledisdb/wiki/Clients) to find or contribute LedisDB client.
|
|
|
|
## Links
|
|
|
|
+ [Official Website](https://ledisdb.io)
|
|
+ [GoDoc](https://godoc.org/git.internal/re/ledisdb)
|
|
+ [Server Commands](https://git.internal/re/ledisdb/wiki/Commands)
|
|
|
|
## Caveat
|
|
|
|
+ Changing the backend database at runtime is very dangerous. Data validation is not guaranteed if this is done.
|
|
|
|
## Requirement
|
|
|
|
+ Go version >= 1.11
|
|
|
|
## Related Repos
|
|
|
|
+ [pika](https://github.com/Qihoo360/pika)
|
|
|
|
## Donate
|
|
|
|
If you like the project and want to buy me a cola, you can through:
|
|
|
|
|PayPal|微信|
|
|
|------|---|
|
|
|[![](https://www.paypalobjects.com/webstatic/paypalme/images/pp_logo_small.png)](https://paypal.me/siddontang)|[![](https://github.com/siddontang/blog/blob/master/donate/weixin.png)|
|
|
|
|
## Feedback
|
|
|
|
+ Gmail: siddontang@gmail.com
|