indextree

package
v0.6.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jan 23, 2024 License: Apache-2.0 Imports: 10 Imported by: 2

Documentation

Index

Constants

View Source
const (
	MaxKeyLength     = 8192
	RecentBlockCount = 128
)

Variables

This section is empty.

Functions

This section is empty.

Types

type BackwardIter

type BackwardIter struct {
	// contains filtered or unexported fields
}

func (*BackwardIter) Close

func (iter *BackwardIter) Close()

func (*BackwardIter) Domain

func (iter *BackwardIter) Domain() ([]byte, []byte)

func (*BackwardIter) Key

func (iter *BackwardIter) Key() []byte

func (*BackwardIter) Next

func (iter *BackwardIter) Next()

func (*BackwardIter) Valid

func (iter *BackwardIter) Valid() bool

func (*BackwardIter) Value

func (iter *BackwardIter) Value() int64

type BackwardIterMem

type BackwardIterMem struct {
	// contains filtered or unexported fields
}

func (*BackwardIterMem) Close

func (iter *BackwardIterMem) Close()

func (*BackwardIterMem) Domain

func (iter *BackwardIterMem) Domain() ([]byte, []byte)

func (*BackwardIterMem) Key

func (iter *BackwardIterMem) Key() []byte

func (*BackwardIterMem) Next

func (iter *BackwardIterMem) Next()

func (*BackwardIterMem) Valid

func (iter *BackwardIterMem) Valid() bool

func (*BackwardIterMem) Value

func (iter *BackwardIterMem) Value() int64

type Cache

type Cache struct {
	// contains filtered or unexported fields
}

func NewCache

func NewCache() *Cache

func (*Cache) Get

func (cache *Cache) Get(k uint64) (v int64, ok bool)

func (*Cache) Set

func (cache *Cache) Set(k uint64, v int64)

type ForwardIter

type ForwardIter struct {
	// contains filtered or unexported fields
}

func (*ForwardIter) Close

func (iter *ForwardIter) Close()

func (*ForwardIter) Domain

func (iter *ForwardIter) Domain() ([]byte, []byte)

func (*ForwardIter) Key

func (iter *ForwardIter) Key() []byte

func (*ForwardIter) Next

func (iter *ForwardIter) Next()

func (*ForwardIter) Valid

func (iter *ForwardIter) Valid() bool

func (*ForwardIter) Value

func (iter *ForwardIter) Value() int64

type ForwardIterMem

type ForwardIterMem struct {
	// contains filtered or unexported fields
}

func (*ForwardIterMem) Close

func (iter *ForwardIterMem) Close()

func (*ForwardIterMem) Domain

func (iter *ForwardIterMem) Domain() ([]byte, []byte)

func (*ForwardIterMem) Key

func (iter *ForwardIterMem) Key() []byte

func (*ForwardIterMem) Next

func (iter *ForwardIterMem) Next()

func (*ForwardIterMem) Valid

func (iter *ForwardIterMem) Valid() bool

func (*ForwardIterMem) Value

func (iter *ForwardIterMem) Value() int64

type HeightCompactionFilter

type HeightCompactionFilter struct {
	// contains filtered or unexported fields
}

We use rocksdb's customizable compact filter to prune old records

func (*HeightCompactionFilter) Filter

func (f *HeightCompactionFilter) Filter(level int, key, val []byte) (remove bool, newVal []byte)

The last 8 bytes of keys are expiring height. If it is too small, we prune the record

func (*HeightCompactionFilter) Name

func (f *HeightCompactionFilter) Name() string

type Iterator

type Iterator = types.IteratorUI64

type MockIndexTree

type MockIndexTree struct {
	// contains filtered or unexported fields
}

func NewMockIndexTree

func NewMockIndexTree() *MockIndexTree

func (*MockIndexTree) ActiveCount

func (it *MockIndexTree) ActiveCount() int

func (*MockIndexTree) BeginWrite

func (it *MockIndexTree) BeginWrite(height int64)

func (*MockIndexTree) Close

func (it *MockIndexTree) Close()

func (*MockIndexTree) Delete

func (it *MockIndexTree) Delete(key []byte)

func (*MockIndexTree) EndWrite

func (it *MockIndexTree) EndWrite()

func (*MockIndexTree) Get

func (it *MockIndexTree) Get(key []byte) (int64, bool)

func (*MockIndexTree) GetAtHeight

func (it *MockIndexTree) GetAtHeight(k []byte, height uint64) (int64, bool)

func (*MockIndexTree) Init

func (it *MockIndexTree) Init(repFn func([]byte)) error

func (*MockIndexTree) Iterator

func (it *MockIndexTree) Iterator(start, end []byte) Iterator

Create a forward iterator from the B-Tree

func (*MockIndexTree) ReverseIterator

func (it *MockIndexTree) ReverseIterator(start, end []byte) Iterator

Create a backward iterator from the B-Tree

func (*MockIndexTree) Set

func (it *MockIndexTree) Set(key []byte, v int64)

func (*MockIndexTree) SetDuringInit

func (tree *MockIndexTree) SetDuringInit(b bool)

func (*MockIndexTree) SetPruneHeight

func (it *MockIndexTree) SetPruneHeight(h uint64)

type NVTreeMem

type NVTreeMem struct {
	// contains filtered or unexported fields
}

func NewNVTreeMem

func NewNVTreeMem(rocksdb *RocksDB) *NVTreeMem

func (*NVTreeMem) ActiveCount

func (tree *NVTreeMem) ActiveCount() int

func (*NVTreeMem) BeginWrite

func (tree *NVTreeMem) BeginWrite(currHeight int64)

Begin the write phase of block execution

func (*NVTreeMem) Close

func (tree *NVTreeMem) Close()

func (*NVTreeMem) Delete

func (tree *NVTreeMem) Delete(k []byte)

Delete a key-position record in B-Tree and RocksDB Write the historical record to RocksDB

func (*NVTreeMem) EndWrite

func (tree *NVTreeMem) EndWrite()

End the write phase of block execution

func (*NVTreeMem) Get

func (tree *NVTreeMem) Get(k []byte) (int64, bool)

Get the up-to-date position of k, from the B-Tree

func (*NVTreeMem) GetAtHeight

func (tree *NVTreeMem) GetAtHeight(k []byte, height uint64) (position int64, ok bool)

Get the position of k, at the specified height.

func (*NVTreeMem) Init

func (tree *NVTreeMem) Init(repFn func([]byte)) (err error)

Load the RocksDB and use its up-to-date records to initialize the in-memory B-Tree. RocksDB's historical records are ignored.

func (*NVTreeMem) Iterator

func (tree *NVTreeMem) Iterator(start, end []byte) Iterator

Create a forward iterator from the B-Tree

func (*NVTreeMem) ReverseIterator

func (tree *NVTreeMem) ReverseIterator(start, end []byte) Iterator

Create a backward iterator from the B-Tree

func (*NVTreeMem) Set

func (tree *NVTreeMem) Set(k []byte, v int64)

Update or insert a key-position record to B-Tree and RocksDB Write the historical record to RocksDB

func (*NVTreeMem) SetDuringInit

func (tree *NVTreeMem) SetDuringInit(b bool)

type RecentCache

type RecentCache struct {
	// contains filtered or unexported fields
}

func (*RecentCache) AllocateIfNotExist

func (rc *RecentCache) AllocateIfNotExist(h int64)

func (*RecentCache) DidNotTouchInRange

func (rc *RecentCache) DidNotTouchInRange(start, end int64, k uint64) bool

func (*RecentCache) FindFirstChangeBefore

func (rc *RecentCache) FindFirstChangeBefore(height int64, k uint64) (v int64, foundIt bool)

func (*RecentCache) Prune

func (rc *RecentCache) Prune(h int64)

type RocksDB

type RocksDB struct {
	// contains filtered or unexported fields
}

func NewRocksDB

func NewRocksDB(name string, dir string) (*RocksDB, error)

func NewRocksDBWithOptions

func NewRocksDBWithOptions(name string, dir string, opts *gorocksdb.Options) (*RocksDB, error)

func (*RocksDB) Close

func (db *RocksDB) Close()

Implements DB.

func (*RocksDB) CloseOldBatch

func (db *RocksDB) CloseOldBatch()

func (*RocksDB) CurrBatch

func (db *RocksDB) CurrBatch() types.Batch

func (*RocksDB) DB

func (db *RocksDB) DB() *gorocksdb.DB

func (*RocksDB) Delete

func (db *RocksDB) Delete(key []byte)

Implements DB.

func (*RocksDB) DeleteSync

func (db *RocksDB) DeleteSync(key []byte)

Implements DB.

func (*RocksDB) Get

func (db *RocksDB) Get(key []byte) []byte

Implements DB.

func (*RocksDB) GetPruneHeight

func (db *RocksDB) GetPruneHeight() (uint64, bool)

func (*RocksDB) Has

func (db *RocksDB) Has(key []byte) bool

Implements DB.

func (*RocksDB) Iterator

func (db *RocksDB) Iterator(start, end []byte) types.Iterator

func (*RocksDB) LockBatch

func (db *RocksDB) LockBatch()

func (*RocksDB) NewBatch

func (db *RocksDB) NewBatch() types.Batch

Implements DB.

func (*RocksDB) OpenNewBatch

func (db *RocksDB) OpenNewBatch()

func (*RocksDB) Print

func (db *RocksDB) Print()

Implements DB.

func (*RocksDB) ReverseIterator

func (db *RocksDB) ReverseIterator(start, end []byte) types.Iterator

func (*RocksDB) Set

func (db *RocksDB) Set(key []byte, value []byte)

Implements DB.

func (*RocksDB) SetPruneHeight

func (db *RocksDB) SetPruneHeight(h uint64)

func (*RocksDB) SetSync

func (db *RocksDB) SetSync(key []byte, value []byte)

Implements DB.

func (*RocksDB) Stats

func (db *RocksDB) Stats() map[string]string

Implements DB.

func (*RocksDB) UnlockBatch

func (db *RocksDB) UnlockBatch()

Directories

Path Synopsis
b

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL