Golang版本的rocksdb-對gorocksdb的封裝

rocksdb的優秀特性不用多說,可是它是用c++語言寫的,就是這一個特色就把不少人攔住了。雖然rocksdb官方也有Java版本,可是Golang的發展速度讓人不容小覷,並且因爲golang原生對高併發的高效性能,golang版本的rocksdb接口非常須要。c++

實例以下git


 

package main

import (
    "github.com/leeyazhou/gorocksdb"
    "log"
    "errors"
    "strconv"
)

const (
    DB_PATH = "/tmp/gorocksdb"
)

func main() {
    db, err := OpenDB()
    if err != nil {
        log.Println("fail to open db,", nil, db)
    }

    readOptions := gorocksdb.NewDefaultReadOptions()
    readOptions.SetFillCache(true)

    writeOptions := gorocksdb.NewDefaultWriteOptions()
    writeOptions.SetSync(true)

    for i := 0; i < 10000; i++ {
        keyStr := "aa" + strconv.Itoa(i)
        var key []byte = []byte(keyStr)
        db.Put(writeOptions, key, key)
        log.Println(i, keyStr)
        slice, err2 := db.Get(readOptions, key)
        if err2 != nil {
            log.Println("獲取數據異常:", key, err2)
            continue
        }
        log.Println("獲取數據:", slice.Size(), string(slice.Data()))
    }

    //defer readOptions.Destroy()
    //defer writeOptions.Destroy()
}

func OpenDB() (*gorocksdb.DB, error) {
    options := gorocksdb.NewDefaultOptions()
    options.SetCreateIfMissing(true)

    bloomFilter := gorocksdb.NewBloomFilter(10)

    readOptions := gorocksdb.NewDefaultReadOptions()
    readOptions.SetFillCache(false)

    rateLimiter := gorocksdb.NewRateLimiter(10000000, 10000, 10)
    options.SetRateLimiter(rateLimiter)
    options.SetCreateIfMissing(true)
    options.EnableStatistics()
    options.SetWriteBufferSize(8 * gorocksdb.KB)
    options.SetMaxWriteBufferNumber(3)
    options.SetMaxBackgroundCompactions(10)
    options.SetCompression(gorocksdb.SnappyCompression)
    options.SetCompactionStyle(gorocksdb.UniversalCompactionStyle)

    options.SetHashSkipListRep(2000000, 4, 4)

    blockBasedTableOptions := gorocksdb.NewDefaultBlockBasedTableOptions()
    blockBasedTableOptions.SetBlockCache(gorocksdb.NewLRUCache(64 * gorocksdb.KB))
    blockBasedTableOptions.SetFilterPolicy(bloomFilter)
    blockBasedTableOptions.SetBlockSizeDeviation(5)
    blockBasedTableOptions.SetBlockRestartInterval(10)
    blockBasedTableOptions.SetBlockCacheCompressed(gorocksdb.NewLRUCache(64 * gorocksdb.KB))
    blockBasedTableOptions.SetCacheIndexAndFilterBlocks(true)
    blockBasedTableOptions.SetIndexType(gorocksdb.KHashSearchIndexType)

    options.SetBlockBasedTableFactory(blockBasedTableOptions)
    //log.Println(bloomFilter, readOptions)
    options.SetPrefixExtractor(gorocksdb.NewFixedPrefixTransform(3))

    options.SetAllowConcurrentMemtableWrites(false)

    db, err := gorocksdb.OpenDb(options, DB_PATH)

    if err != nil {
        log.Fatalln("OPEN DB error", db, err)
        db.Close()
        return nil, errors.New("fail to open db")
    } else {
        log.Println("OPEN DB success", db)
    }
    return db, nil
}
相關文章
相關標籤/搜索