1.levelDB 只能实现单点部署,但是以文件的方式存贮数据,所以性能方面就会比其他的高相关链接
2.官网地址
3.golang leveldb client 地址 使用案例
1. 安装,要求 go版本>=1.4.
go get github.com/syndtr/goleveldb/leveldb2 使用 创建数据库,一个路径就是一个数据库
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)遍历
1. iter := db.NewIterator(nil, nil) for iter.Next() { key := iter.Key() value := iter.Value() ... } iter.Release() err = iter.Error() 2. iter := db.NewIterator(nil, nil) for ok := iter.Seek(key); ok; ok = iter.Next() { // Use key/value. ... } iter.Release() err = iter.Error() ... 3. iter := db.NewIterator(&util.Range{Start: []byte("foo"), Limit: []byte("xoo")}, nil) for iter.Next() { // Use key/value. ... } iter.Release() err = iter.Error() 4. 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(10), } db, err := leveldb.OpenFile("path/to/db", o) defer db.Close()基本上就这些了,只是简单地写了一下:)