// NewLevelDBStorage is a constructor of DataStorage. func NewLevelDBStorage(cfg *conf.Config) (*LevelDBStorage, error) { ds := LevelDBStorage{ cfg: cfg, dbName: cfg.DatabasePath, itemCache: make(ItemCache), tmpItemCache: make(ItemCache), closed: false, forceFlushChan: make(chan bool, 1), flushSync: &sync.WaitGroup{}, } // LevelDB write options. opts := new(opt.Options) opts.Compression = opt.NoCompression opts.BlockCacheCapacity = 8 * 1024 * 1024 opts.WriteBuffer = 8 * 1024 * 1024 db, err := leveldb.OpenFile(cfg.DatabasePath, opts) if err != nil { return nil, err } ds.db = db go ds.periodicCacheFlush() return &ds, nil }
func applyConfig(o *opt.Options, config map[string]interface{}) ( *opt.Options, error) { ro, ok := config["read_only"].(bool) if ok { o.ReadOnly = ro } cim, ok := config["create_if_missing"].(bool) if ok { o.ErrorIfMissing = !cim } eie, ok := config["error_if_exists"].(bool) if ok { o.ErrorIfExist = eie } wbs, ok := config["write_buffer_size"].(float64) if ok { o.WriteBuffer = int(wbs) } bs, ok := config["block_size"].(float64) if ok { o.BlockSize = int(bs) } bri, ok := config["block_restart_interval"].(float64) if ok { o.BlockRestartInterval = int(bri) } lcc, ok := config["lru_cache_capacity"].(float64) if ok { o.BlockCacheCapacity = int(lcc) } bfbpk, ok := config["bloom_filter_bits_per_key"].(float64) if ok { bf := filter.NewBloomFilter(int(bfbpk)) o.Filter = bf } return o, nil }