erigon-pulse/ethdb/kv_abstract.go
Alex Sharov 57358730a4
Minor lmdb related improvements (#667)
* don't call initCursor on happy path

* don't call initCursor on happy path

* don't run stale reads goroutine for inMem mode

* don't call initCursor on happy path

* remove buffers from cursor object - they are useful only in Badger implementation

* commit kv benchmark

* remove buffers from cursor object - they are useful only in Badger implementation

* remove buffers from cursor object - they are useful only in Badger implementation

* cancel server before return pipe to pool

* try  to fix test

* set field db in managed tx
2020-06-15 13:30:54 +01:00

74 lines
1.5 KiB
Go

package ethdb
import (
"context"
"github.com/ledgerwatch/turbo-geth/common"
)
type KV interface {
View(ctx context.Context, f func(tx Tx) error) error
Update(ctx context.Context, f func(tx Tx) error) error
Close()
Begin(ctx context.Context, writable bool) (Tx, error)
}
type NativeGet interface {
Get(ctx context.Context, bucket, key []byte) ([]byte, error)
Has(ctx context.Context, bucket, key []byte) (bool, error)
}
type Tx interface {
Bucket(name []byte) Bucket
Commit(ctx context.Context) error
Rollback() error
}
type Bucket interface {
Get(key []byte) (val []byte, err error)
Put(key []byte, value []byte) error
Delete(key []byte) error
Cursor() Cursor
Size() (uint64, error)
}
type Cursor interface {
Prefix(v []byte) Cursor
MatchBits(uint) Cursor
Prefetch(v uint) Cursor
NoValues() NoValuesCursor
First() ([]byte, []byte, error)
Seek(seek []byte) ([]byte, []byte, error)
SeekTo(seek []byte) ([]byte, []byte, error)
Next() ([]byte, []byte, error)
Walk(walker func(k, v []byte) (bool, error)) error
Put(key []byte, value []byte) error
Delete(key []byte) error
}
type NoValuesCursor interface {
First() ([]byte, uint32, error)
Seek(seek []byte) ([]byte, uint32, error)
Next() ([]byte, uint32, error)
Walk(walker func(k []byte, vSize uint32) (bool, error)) error
}
type HasStats interface {
DiskSize(context.Context) (common.StorageSize, error) // db size
BucketsStat(context.Context) (map[string]common.StorageBucketWriteStats, error)
}
type DbProvider uint8
const (
Bolt DbProvider = iota
Badger
Remote
Lmdb
)