From d369bd5c3c7f79967bb73e6132eab63c406d9531 Mon Sep 17 00:00:00 2001 From: Mark Mindenhall Date: Mon, 13 Jun 2016 18:47:38 -0600 Subject: [PATCH] Add bucket fill percent option for boltdb --- index/store/boltdb/store.go | 27 +++++++++++++++++---------- index/store/boltdb/writer.go | 1 + 2 files changed, 18 insertions(+), 10 deletions(-) diff --git a/index/store/boltdb/store.go b/index/store/boltdb/store.go index 163a0566..5587aafe 100644 --- a/index/store/boltdb/store.go +++ b/index/store/boltdb/store.go @@ -33,11 +33,12 @@ const ( ) type Store struct { - path string - bucket string - db *bolt.DB - noSync bool - mo store.MergeOperator + path string + bucket string + db *bolt.DB + noSync bool + fillPercent float64 + mo store.MergeOperator } func New(mo store.MergeOperator, config map[string]interface{}) (store.KVStore, error) { @@ -53,6 +54,11 @@ func New(mo store.MergeOperator, config map[string]interface{}) (store.KVStore, noSync, _ := config["nosync"].(bool) + fillPercent, ok := config["fillPercent"].(float64) + if !ok { + fillPercent = bolt.DefaultFillPercent + } + db, err := bolt.Open(path, 0600, nil) if err != nil { return nil, err @@ -69,11 +75,12 @@ func New(mo store.MergeOperator, config map[string]interface{}) (store.KVStore, } rv := Store{ - path: path, - bucket: bucket, - db: db, - mo: mo, - noSync: noSync, + path: path, + bucket: bucket, + db: db, + mo: mo, + noSync: noSync, + fillPercent: fillPercent, } return &rv, nil } diff --git a/index/store/boltdb/writer.go b/index/store/boltdb/writer.go index 4ba1d082..a758efa6 100644 --- a/index/store/boltdb/writer.go +++ b/index/store/boltdb/writer.go @@ -40,6 +40,7 @@ func (w *Writer) ExecuteBatch(batch store.KVBatch) error { } bucket := tx.Bucket([]byte(w.store.bucket)) + bucket.FillPercent = w.store.fillPercent for k, mergeOps := range emulatedBatch.Merger.Merges { kb := []byte(k)