Documentation ¶
Overview ¶
Package store_rocksdb implements the consumer.Store interface via an embedded RocksDB instance. To enable recording of RocksDB file operations it defines EnvObserver and WritableFileObserver, which roughly match the C++ interfaces of rocksdb::Env and rocksdb::WritableFile. A "hooked" environment implementation wraps the default rocksdb::Env to dispatch EnvObserver calls upon each matched method call of the delegate rocksdb::Env. This allows observers to inspect file operations initiated by the database as they're happening.
NewRecorder() then adapts a *recoverylog.Recorder to be an EnvObserver, and Store provides the top-level wiring for building a recorded RocksDB instance which satisfies the consumer.Store interface.
This package also offers ArenaIterator, which wraps a gorocksdb.Iterator in order to amortize the number of CGO calls required when iterating through a database, potentially providing a substantial speedup:
BenchmarkIterator/direct-iterator-8 3000 428699 ns/op BenchmarkIterator/arena-iterator-8 20000 73638 ns/op
Index ¶
- func NewHookedEnv(obv EnvObserver) *gorocksdb.Env
- type ArenaIterator
- func (it *ArenaIterator) Close()
- func (it *ArenaIterator) Err() error
- func (it *ArenaIterator) Key() []byte
- func (it *ArenaIterator) Next()
- func (it *ArenaIterator) Prev()
- func (it *ArenaIterator) Seek(key []byte)
- func (it *ArenaIterator) SeekForPrev(key []byte)
- func (it *ArenaIterator) SeekToFirst()
- func (it *ArenaIterator) SeekToLast()
- func (it *ArenaIterator) Valid() bool
- func (it *ArenaIterator) ValidForPrefix(prefix []byte) bool
- func (it *ArenaIterator) Value() []byte
- type EnvObserver
- type Store
- type WritableFileObserver
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func NewHookedEnv ¶
func NewHookedEnv(obv EnvObserver) *gorocksdb.Env
NewHookedEnv returns a "hooked" RocksDB Environment which delegates to a default RocksDB Environment and then informs the provided EnvObserver of method calls on that Environment.
Types ¶
type ArenaIterator ¶
type ArenaIterator struct {
// contains filtered or unexported fields
}
ArenaIterator adapts a gorocksdb.Iterator to amortize CGO calls by pre-fetching multiple keys and values into a memory arena. This is generally a performance win in the common case of stepping through via Next() with minimal seeking.
It's interface and semantics matches that of gorocksdb.Iterator, with the exception that Key() and Value() return []byte rather than a gorocksdb.Slice.
func AsArenaIterator ¶
func AsArenaIterator(it *gorocksdb.Iterator, arena []byte) *ArenaIterator
AsArenaIterator adapts a gorocksdb.Iterator to an ArenaIterator that pre-fetches multiple keys & values into |arena| via a single CGO call.
func (*ArenaIterator) Err ¶
func (it *ArenaIterator) Err() error
Err returns nil if no errors happened during iteration, or the actual error otherwise.
func (*ArenaIterator) Key ¶
func (it *ArenaIterator) Key() []byte
Key returns the key the iterator currently holds.
func (*ArenaIterator) Next ¶
func (it *ArenaIterator) Next()
Next moves the iterator to the next sequential key in the database.
func (*ArenaIterator) Prev ¶
func (it *ArenaIterator) Prev()
Prev moves the iterator to the previous sequential key in the database.
func (*ArenaIterator) Seek ¶
func (it *ArenaIterator) Seek(key []byte)
Seek moves the iterator to the position greater than or equal to the key.
func (*ArenaIterator) SeekForPrev ¶
func (it *ArenaIterator) SeekForPrev(key []byte)
SeekForPrev moves the iterator to the last key that less than or equal to the target key, in contrast with Seek.
func (*ArenaIterator) SeekToFirst ¶
func (it *ArenaIterator) SeekToFirst()
SeekToFirst moves the iterator to the first key in the database.
func (*ArenaIterator) SeekToLast ¶
func (it *ArenaIterator) SeekToLast()
SeekToLast moves the iterator to the last key in the database.
func (*ArenaIterator) Valid ¶
func (it *ArenaIterator) Valid() bool
Valid returns false only when an Iterator has iterated past either the first or the last key in the database.
func (*ArenaIterator) ValidForPrefix ¶
func (it *ArenaIterator) ValidForPrefix(prefix []byte) bool
ValidForPrefix returns false only when an Iterator has iterated past the first or the last key in the database or the specified prefix.
func (*ArenaIterator) Value ¶
func (it *ArenaIterator) Value() []byte
Value returns the value in the database the iterator currently holds.
type EnvObserver ¶
type EnvObserver interface { // Invoked just before a new WritableFile is created. Returns a // WritableFileObserver which is associated with the result file. NewWritableFile(fname string) WritableFileObserver // Invoked just before |fname| is deleted. DeleteFile(fname string) // Invoked just before |dirname| is deleted. DeleteDir(dirname string) // Invoked just before |src| is renamed to |target|. RenameFile(src, target string) // Invoked just before |src| is linked to |target|. LinkFile(src, target string) }
EnvObserver allows for observation of mutating Env operations. Consult |Env| in rocksdb/env.h for further details.
func NewRecorder ¶
func NewRecorder(recorder *recoverylog.Recorder) EnvObserver
NewRecorder adapts a recoverylog.Recorder to an EnvObserver.
type Store ¶
type Store struct { DB *rocks.DB Env *rocks.Env Options *rocks.Options ReadOptions *rocks.ReadOptions WriteBatch *rocks.WriteBatch WriteOptions *rocks.WriteOptions // Cache is a convenient mechanism for consumers to associate shard-specific, // in-memory state with a Store, typically for performance reasons. // Examples might include: // // - Records we expect to reduce / aggregate over multiple times in a consumer // transaction, and want to write to the DB only once per transaction (ie, // as part of a consumer Flush). // - An LRU of "hot" records we expect to reference again soon. // // The representation of Cache is up to the consumer; it is not directly used // by Store. Cache interface{} // contains filtered or unexported fields }
Store implements the consumer.Store interface.
func NewStore ¶
func NewStore(recorder *recoverylog.Recorder) *Store
NewStore builds a Store which is prepared to open its database, but has not yet done so. The caller may wish to further tweak Options and Env settings, and should then call Open to open the database.
func (*Store) RestoreCheckpoint ¶ added in v0.83.1
RestoreCheckpoint implements consumer.Store.
type WritableFileObserver ¶
type WritableFileObserver interface { // Invoked when |data| is appended to the file. Note that |data| is owned by // RocksDB and must not be referenced after this call. Append(data []byte) // Invoked when the file is closed. Close() // Invoked when the file is Synced. Sync() // Invoked when the file is Fsync'd. Note that this may in turn // delegate to sync, and result in a call to the Sync() observer. Fsync() // Invoked when the file is RangeSync'd. RangeSync(offset, nbytes uint64) }
WritableFileObserver allows for observation of mutating WritableFile operations. Consult |WritableFile| in rocksdb/env.h for further details.