1.levelDB 隻能實作單點部署,但是以檔案的方式存貯資料,是以性能方面就會比其他的高相關連結
2.官網位址
3.golang leveldb client 位址
使用案例
1. 安裝,要求 go版本>=1.4.
go get github.com/syndtr/goleveldb/leveldb
2 使用
建立資料庫,一個路徑就是一個資料庫
package main
import(
"github.com/syndtr/goleveldb/leveldb"
"fmt"
)
db, err := leveldb.OpenFile("path/to/db", nil)
if err!=nil{
fmt.println("create levedb database failed",err);
return
}
fmt.println("%#v",db);
//defer db.Close() 建議設定成全局變量
擷取對應的key的value
data, err := db.Get([]byte("key"), nil)
設定或者修改key的value
err = db.Put([]byte("key"), []byte("value"), nil)
删除對應key的value
err = db.Delete([]byte("key"), nil)
周遊
iter := db.NewIterator(nil, nil)
for iter.Next() {
key := iter.Key()
value := iter.Value()
...
}
iter.Release()
err = iter.Error()
iter := db.NewIterator(nil, nil)
for ok := iter.Seek(key); ok; ok = iter.Next() {
// Use key/value.
...
}
iter.Release()
err = iter.Error()
...
iter := db.NewIterator(&util.Range{Start: []byte("foo"), Limit: []byte("xoo")}, nil)
for iter.Next() {
// Use key/value.
...
}
iter.Release()
err = iter.Error()
iter := db.NewIterator(util.BytesPrefix([]byte("foo-")), nil)
for iter.Next() {
// Use key/value.
...
}
iter.Release()
err = iter.Error()
批量指派
batch := new(leveldb.Batch)
batch.Put([]byte("foo"), []byte("value"))
batch.Put([]byte("bar"), []byte("another value"))
batch.Delete([]byte("baz"))
err = db.Write(batch, nil)
過濾
o := &opt.Options{
Filter: filter.NewBloomFilter(),
}
db, err := leveldb.OpenFile("path/to/db", o)
defer db.Close()
基本上就這些了,隻是簡單地寫了一下:)