镜像自地址
https://github.com/tuna/tunasync.git
已同步 2025-12-06 06:26:46 +00:00
Add badger to db backend
这个提交包含在:
@@ -7,6 +7,7 @@ import (
|
||||
"time"
|
||||
|
||||
"github.com/boltdb/bolt"
|
||||
"github.com/dgraph-io/badger/v2"
|
||||
"github.com/go-redis/redis/v8"
|
||||
|
||||
. "github.com/tuna/tunasync/internal"
|
||||
@@ -72,6 +73,19 @@ func makeDBAdapter(dbType string, dbFile string) (dbAdapter, error) {
|
||||
}
|
||||
err = kv.Init()
|
||||
return &kv, err
|
||||
} else if dbType == "badger" {
|
||||
innerDB, err := badger.Open(badger.DefaultOptions(dbFile))
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
db := badgerAdapter{
|
||||
db: innerDB,
|
||||
}
|
||||
kv := kvDBAdapter{
|
||||
db: &db,
|
||||
}
|
||||
err = kv.Init()
|
||||
return &kv, err
|
||||
}
|
||||
// unsupported db-type
|
||||
return nil, fmt.Errorf("unsupported db-type: %s", dbType)
|
||||
|
||||
67
manager/db_badger.go
普通文件
67
manager/db_badger.go
普通文件
@@ -0,0 +1,67 @@
|
||||
package manager
|
||||
|
||||
import (
|
||||
"github.com/dgraph-io/badger/v2"
|
||||
)
|
||||
|
||||
// implement kv interface backed by badger
|
||||
type badgerAdapter struct {
|
||||
db *badger.DB
|
||||
}
|
||||
|
||||
func (b *badgerAdapter) InitBucket(bucket string) (err error) {
|
||||
// no-op
|
||||
return
|
||||
}
|
||||
|
||||
func (b *badgerAdapter) Get(bucket string, key string) (v []byte, err error) {
|
||||
b.db.View(func(tx *badger.Txn) error {
|
||||
var item *badger.Item
|
||||
item, err = tx.Get([]byte(bucket + key))
|
||||
if item != nil {
|
||||
v, err = item.ValueCopy(nil)
|
||||
}
|
||||
return nil
|
||||
})
|
||||
return
|
||||
}
|
||||
|
||||
func (b *badgerAdapter) GetAll(bucket string) (m map[string][]byte, err error) {
|
||||
b.db.View(func(tx *badger.Txn) error {
|
||||
it := tx.NewIterator(badger.DefaultIteratorOptions)
|
||||
defer it.Close()
|
||||
prefix := []byte(bucket)
|
||||
m = make(map[string][]byte)
|
||||
for it.Seek(prefix); it.ValidForPrefix(prefix); it.Next() {
|
||||
item := it.Item()
|
||||
k := string(item.Key())
|
||||
actualKey := k[len(bucket):]
|
||||
|
||||
var v []byte
|
||||
v, err = item.ValueCopy(nil)
|
||||
m[actualKey] = v
|
||||
}
|
||||
return nil
|
||||
})
|
||||
return
|
||||
}
|
||||
|
||||
func (b *badgerAdapter) Put(bucket string, key string, value []byte) error {
|
||||
err := b.db.Update(func(tx *badger.Txn) error {
|
||||
err := tx.Set([]byte(bucket+key), value)
|
||||
return err
|
||||
})
|
||||
return err
|
||||
}
|
||||
|
||||
func (b *badgerAdapter) Delete(bucket string, key string) error {
|
||||
err := b.db.Update(func(tx *badger.Txn) error {
|
||||
err := tx.Delete([]byte(bucket + key))
|
||||
return err
|
||||
})
|
||||
return err
|
||||
}
|
||||
|
||||
func (b *badgerAdapter) Close() error {
|
||||
return b.db.Close()
|
||||
}
|
||||
@@ -162,7 +162,7 @@ func DBAdapterTest(db dbAdapter) {
|
||||
return
|
||||
}
|
||||
|
||||
func TestBoltAdapter(t *testing.T) {
|
||||
func TestDBAdapter(t *testing.T) {
|
||||
Convey("boltAdapter should work", t, func() {
|
||||
tmpDir, err := ioutil.TempDir("", "tunasync")
|
||||
defer os.RemoveAll(tmpDir)
|
||||
@@ -198,4 +198,22 @@ func TestBoltAdapter(t *testing.T) {
|
||||
|
||||
DBAdapterTest(redisDB)
|
||||
})
|
||||
|
||||
Convey("badgerAdapter should work", t, func() {
|
||||
tmpDir, err := ioutil.TempDir("", "tunasync")
|
||||
defer os.RemoveAll(tmpDir)
|
||||
So(err, ShouldBeNil)
|
||||
|
||||
dbType, dbFile := "badger", filepath.Join(tmpDir, "badger.db")
|
||||
badgerDB, err := makeDBAdapter(dbType, dbFile)
|
||||
So(err, ShouldBeNil)
|
||||
|
||||
defer func() {
|
||||
// close badgerDB
|
||||
err := badgerDB.Close()
|
||||
So(err, ShouldBeNil)
|
||||
}()
|
||||
|
||||
DBAdapterTest(badgerDB)
|
||||
})
|
||||
}
|
||||
|
||||
在新工单中引用
屏蔽一个用户