Documentation
¶
Index ¶
- Constants
- Variables
- func ApplyProfile(opts *Options, profile Profile)
- func DisableValueLogDictCompression(opts *Options)
- func EnableValueLogDictCompression(opts *Options)
- func OpenBackend(opts Options) (*db.DB, func() error, error)
- func VacuumIndexOffline(opts Options) error
- type AutotuneMode
- type AutotuneOptions
- type Batch
- type DB
- func (db *DB) AcquireSnapshot() Snapshot
- func (db *DB) Checkpoint() error
- func (db *DB) Close() error
- func (db *DB) CompactIndex() error
- func (db *DB) Delete(key []byte) error
- func (db *DB) DeleteRange(start, end []byte) error
- func (db *DB) DeleteSync(key []byte) error
- func (db *DB) DurabilityMode() string
- func (db *DB) FragmentationReport() (map[string]string, error)
- func (db *DB) Get(key []byte) ([]byte, error)
- func (db *DB) GetAppend(key, dst []byte) ([]byte, error)
- func (db *DB) GetMany(keys [][]byte) ([][]byte, error)
- func (db *DB) GetManyParallelPlan(keyCount int) (workers int, parallel bool)
- func (db *DB) GetUnsafe(key []byte) ([]byte, error)
- func (db *DB) Has(key []byte) (bool, error)
- func (db *DB) Iterator(start, end []byte) (Iterator, error)
- func (db *DB) LeafGenerationGC(ctx context.Context, opts LeafGenerationGCOptions) (LeafGenerationGCStats, error)
- func (db *DB) LeafGenerationPack(ctx context.Context, opts LeafGenerationPackOptions) (LeafGenerationPackStats, error)
- func (db *DB) LeafGenerationPackFromPlan(ctx context.Context, opts LeafGenerationPackFromPlanOptions) (LeafGenerationPackStats, error)
- func (db *DB) LeafGenerationPackRunOnce(ctx context.Context, opts LeafGenerationPackFromPlanOptions) (LeafGenerationPackRunOnceStats, error)
- func (db *DB) LeafGenerationPlan(ctx context.Context, opts LeafGenerationPlanOptions) (LeafGenerationPlan, error)
- func (db *DB) MaintenancePhase() MaintenancePhase
- func (db *DB) NewBatch() Batch
- func (db *DB) NewBatchWithSize(size int) Batch
- func (db *DB) Print() error
- func (db *DB) ReverseIterator(start, end []byte) (Iterator, error)
- func (db *DB) Set(key, value []byte) error
- func (db *DB) SetMaintenancePhase(phase MaintenancePhase)
- func (db *DB) SetSync(key, value []byte) error
- func (db *DB) Stats() map[string]string
- func (db *DB) VacuumIndexOnline(ctx context.Context) error
- func (db *DB) ValueLogGC(ctx context.Context, opts ValueLogGCOptions) (ValueLogGCStats, error)
- func (db *DB) ValueLogRewriteOnline(ctx context.Context, opts ValueLogRewriteOnlineOptions) (ValueLogRewriteStats, error)
- type DictLookup
- type DurabilityMode
- type IntegrityMode
- type Iterator
- type LeafGenerationGCOptions
- type LeafGenerationGCStats
- type LeafGenerationPackFromPlanOptions
- type LeafGenerationPackOptions
- type LeafGenerationPackRunOnceStats
- type LeafGenerationPackSelectOptions
- type LeafGenerationPackSelection
- type LeafGenerationPackStats
- type LeafGenerationPlan
- type LeafGenerationPlanGeneration
- type LeafGenerationPlanOptions
- type MaintenancePhase
- type Options
- type Profile
- type Snapshot
- type TrainConfig
- type ValueLogAutoPolicy
- type ValueLogBlockCodec
- type ValueLogCompressionMode
- type ValueLogDictClassMode
- type ValueLogDomainThreshold
- type ValueLogGCMode
- type ValueLogGCOptions
- type ValueLogGCStats
- type ValueLogGenerationConfig
- type ValueLogGenerationPolicy
- type ValueLogOptions
- type ValueLogRewriteLocalityPolicy
- type ValueLogRewriteOnlineOptions
- type ValueLogRewriteStats
- type ZSTDEncoderLevel
Examples ¶
Constants ¶
const ( DurabilityDurable = db.DurabilityDurable DurabilityWALOnRelaxed = db.DurabilityWALOnRelaxed DurabilityWALOffRelaxed = db.DurabilityWALOffRelaxed )
const ( IntegrityVerify = db.IntegrityVerify IntegritySkipChecksums = db.IntegritySkipChecksums )
const ( ValueLogCompressionOff = db.ValueLogCompressionOff ValueLogCompressionBlock = db.ValueLogCompressionBlock ValueLogCompressionDict = db.ValueLogCompressionDict ValueLogCompressionAuto = db.ValueLogCompressionAuto )
const ( ValueLogBlockSnappy = db.ValueLogBlockSnappy ValueLogBlockLZ4 = db.ValueLogBlockLZ4 )
const ( ValueLogAutoThroughput = db.ValueLogAutoThroughput ValueLogAutoBalanced = db.ValueLogAutoBalanced ValueLogAutoSize = db.ValueLogAutoSize )
const ( ValueLogDictClassSingle = db.ValueLogDictClassSingle ValueLogDictClassSplitOuterLeaf = db.ValueLogDictClassSplitOuterLeaf )
const ( ValueLogGenerationDefault = db.ValueLogGenerationDefault ValueLogGenerationOff = db.ValueLogGenerationOff ValueLogGenerationHotWarmCold = db.ValueLogGenerationHotWarmCold )
const ( AutotuneUnset = valuelog.AutotuneUnset AutotuneOff = valuelog.AutotuneOff AutotuneMedium = valuelog.AutotuneMedium AutotuneAggressive = valuelog.AutotuneAggressive )
const ( ZSTDLevelFastest = zstd.SpeedFastest ZSTDLevelDefault = zstd.SpeedDefault ZSTDLevelBetter = zstd.SpeedBetterCompression ZSTDLevelBest = zstd.SpeedBestCompression )
const ( MaintenancePhaseSteady = caching.MaintenancePhaseSteady MaintenancePhaseRestore = caching.MaintenancePhaseRestore MaintenancePhaseCatchUp = caching.MaintenancePhaseCatchUp )
const ( ValueLogRewriteLocalityDefault = treedbdb.ValueLogRewriteLocalityDefault ValueLogRewriteLocalityGrouped = treedbdb.ValueLogRewriteLocalityGrouped )
Variables ¶
var ( // ErrLocked indicates the database directory is already opened by another process. ErrLocked = db.ErrLocked // ErrMemtableFull indicates the cached memtable has reached its hard cap. ErrMemtableFull = caching.ErrMemtableFull // ErrClosed indicates the DB handle has been closed. ErrClosed = db.ErrClosed // ErrKeyNotFound indicates the key does not exist. ErrKeyNotFound = tree.ErrKeyNotFound )
Functions ¶
func ApplyProfile ¶
ApplyProfile applies a profile to opts without overwriting explicit caller overrides.
For numeric/duration fields, "explicit override" means the field is already set to a non-zero value. For background intervals, note TreeDB conventions:
- `0` means "use default"
- `<0` means "disable"
For booleans, Go does not provide a way to distinguish “unset” from “explicit false”, so profiles set boolean policy knobs to match the profile. If you want the opposite policy, apply the profile and then override the boolean explicitly.
func DisableValueLogDictCompression ¶ added in v0.3.0
func DisableValueLogDictCompression(opts *Options)
DisableValueLogDictCompression disables background dictionary training for value-log frame compression (cached mode).
It does not remove dictdb state on disk; it only prevents training/publishing new dictionaries for future writes.
func EnableValueLogDictCompression ¶ added in v0.3.0
func EnableValueLogDictCompression(opts *Options)
EnableValueLogDictCompression enables background dictionary training for value-log frame compression (cached mode).
This is a convenience helper intended to avoid requiring callers to set many low-level knobs. It sets TrainBytes to a safe default if unset and ensures side stores are enabled so dictionaries can be persisted in dictdb/.
Advanced tuning remains available via opts.ValueLog.DictTrain and opts.ValueLog.CompressionAutotune.
func OpenBackend ¶
OpenBackend opens the TreeDB backend directly (no caching layer) while wiring side-store lookups (dictdb/templatedb) when present.
This is intended for maintenance tooling (e.g. treemap vlog-gc) that must avoid cached-layer side effects but still needs value-log decode plumbing.
func VacuumIndexOffline ¶
VacuumIndexOffline rewrites `index.db` into a fresh file and swaps it in. This is intended to reclaim space and restore locality after long churn.
It is an offline operation: it acquires the exclusive open lock for opts.Dir.
Types ¶
type AutotuneMode ¶ added in v0.3.0
type AutotuneMode = valuelog.AutotuneMode
type AutotuneOptions ¶ added in v0.3.0
type AutotuneOptions = valuelog.AutotuneOptions
type Batch ¶
type Batch interface {
Set(key, value []byte) error
Delete(key []byte) error
Write() error
WriteSync() error
Close() error
Replay(func(batch.Entry) error) error
GetByteSize() (int, error)
}
Batch is the public batch contract returned by TreeDB. Both cached and backend implementations satisfy it.
Example ¶
package main
import (
"fmt"
"os"
treedb "github.com/snissn/gomap/TreeDB"
)
func main() {
dir, err := os.MkdirTemp("", "treedb-batch-example-")
if err != nil {
panic(err)
}
defer os.RemoveAll(dir)
db, err := treedb.Open(treedb.Options{Dir: dir})
if err != nil {
panic(err)
}
defer db.Close()
batch := db.NewBatch()
if batch == nil {
panic("batch creation failed")
}
batch.Set([]byte("key1"), []byte("value1"))
batch.Set([]byte("key2"), []byte("value2"))
batch.Delete([]byte("key1"))
// WriteSync ensures durability.
if err := batch.WriteSync(); err != nil {
panic(err)
}
val, _ := db.Get([]byte("key2"))
fmt.Println("key2:", string(val))
val, _ = db.Get([]byte("key1"))
fmt.Println("key1:", val)
}
Output: key2: value2 key1: []
type DB ¶
type DB struct {
// contains filtered or unexported fields
}
DB is the public TreeDB handle (cached mode by default; read-only opens skip caching).
func Open ¶
Open opens TreeDB. By default it enables caching (write-back layer).
Example ¶
package main
import (
"fmt"
"os"
treedb "github.com/snissn/gomap/TreeDB"
)
func main() {
dir, err := os.MkdirTemp("", "treedb-example-")
if err != nil {
panic(err)
}
defer os.RemoveAll(dir)
db, err := treedb.Open(treedb.Options{Dir: dir, ChunkSize: 64 * 1024})
if err != nil {
panic(err)
}
defer db.Close()
if err := db.SetSync([]byte("k"), []byte("v")); err != nil {
panic(err)
}
val, err := db.Get([]byte("k"))
if err != nil {
panic(err)
}
fmt.Println(string(val))
}
Output: v
func (*DB) AcquireSnapshot ¶
AcquireSnapshot returns a new snapshot.
In cached mode, snapshots include writes that are buffered in memtables. In read-only mode (no caching), snapshots are backend-only.
Callers may use GetUnsafe to obtain zero-copy views tied to the snapshot lifetime.
func (*DB) Checkpoint ¶
Checkpoint forces a durable backend boundary and trims cached-mode WAL segments, so long-running cached-mode workloads do not accumulate unbounded `wal/` growth.
In cached mode this flushes queued memtables with backend sync and resets the WAL to a fresh segment. In backend mode it forces a sync boundary.
func (*DB) CompactIndex ¶
CompactIndex performs an in-place index vacuum (bulk rebuild) on the backend. In cached mode it first drains the caching layer so the backend reflects all buffered writes before rebuilding.
func (*DB) DeleteRange ¶
DeleteRange removes all keys in the range [start, end).
This is primarily used by benchmark suites and maintenance tooling. In cached mode, it may use fast paths that avoid per-key tombstones when safe.
func (*DB) DeleteSync ¶
DeleteSync removes a key and forces a durability boundary.
func (*DB) DurabilityMode ¶
DurabilityMode reports the effective durability/integrity policy string.
func (*DB) FragmentationReport ¶
FragmentationReport returns best-effort structural stats about the on-disk user index that help diagnose scan regressions after churn.
Note: In cached mode this reflects the backend state only; queued memtables are not included unless the caller has explicitly drained the cache (e.g. via close+reopen or a maintenance operation that drains).
func (*DB) GetAppend ¶
GetAppend appends the value for the key to dst and returns the new slice. It avoids internal allocations by using the provided buffer. If the key is not found, it returns dst and ErrKeyNotFound.
func (*DB) GetMany ¶ added in v0.4.0
GetMany returns values for keys.
Semantics: Returns safe copies of values. Missing keys are returned as nil entries with no error.
func (*DB) GetManyParallelPlan ¶ added in v0.4.0
GetManyParallelPlan reports how TreeDB would schedule GetMany for the given key count. It can be used by adapters to enforce external worker budgets without duplicating TreeDB scheduler constants.
func (*DB) GetUnsafe ¶
GetUnsafe returns the value for a key.
Semantics: Returns a safe copy of the value. For zero-copy views tied to a snapshot lifetime, use AcquireSnapshot().GetUnsafe.
func (*DB) LeafGenerationGC ¶ added in v0.5.0
func (db *DB) LeafGenerationGC(ctx context.Context, opts LeafGenerationGCOptions) (LeafGenerationGCStats, error)
LeafGenerationGC deletes fully unreachable, unpinned sealed leaf generations.
In cached mode, this first checkpoints so the backend root used for reachability matches the current public DB state.
func (*DB) LeafGenerationPack ¶ added in v0.5.0
func (db *DB) LeafGenerationPack(ctx context.Context, opts LeafGenerationPackOptions) (LeafGenerationPackStats, error)
LeafGenerationPack copies live pages from sealed source generations into a fresh leaf-log output so whole-generation GC can later reclaim the old files.
In cached mode, this first checkpoints so the backend roots match the current public DB state.
func (*DB) LeafGenerationPackFromPlan ¶ added in v0.5.0
func (db *DB) LeafGenerationPackFromPlan(ctx context.Context, opts LeafGenerationPackFromPlanOptions) (LeafGenerationPackStats, error)
LeafGenerationPackFromPlan computes the current plan, selects a bounded candidate prefix, then packs those sealed generations.
In cached mode, this first checkpoints so the backend roots match the current public DB state.
func (*DB) LeafGenerationPackRunOnce ¶ added in v0.5.0
func (db *DB) LeafGenerationPackRunOnce(ctx context.Context, opts LeafGenerationPackFromPlanOptions) (LeafGenerationPackRunOnceStats, error)
LeafGenerationPackRunOnce computes the current plan, applies bounded selection, and either runs one pack pass or reports why it skipped.
In cached mode, this first checkpoints so the backend roots match the current public DB state.
func (*DB) LeafGenerationPlan ¶ added in v0.5.0
func (db *DB) LeafGenerationPlan(ctx context.Context, opts LeafGenerationPlanOptions) (LeafGenerationPlan, error)
LeafGenerationPlan scans the current live tree and reports per-generation live/dead bytes for explicit leaf-pack planning.
In cached mode, this first checkpoints so the backend roots match the current public DB state.
func (*DB) MaintenancePhase ¶ added in v0.4.0
func (db *DB) MaintenancePhase() MaintenancePhase
func (*DB) NewBatchWithSize ¶
NewBatchWithSize creates a new batch with a best-effort capacity hint.
The size parameter is a best-effort hint, not a strict limit. Small hints are treated like approximate entry reserves. Larger hints may be interpreted as a byte budget and normalized into an internal entry estimate instead. Extremely large hints may also be capped internally.
Callers must not rely on an exact 1:1 mapping between size and the number of entries or bytes that can be written to the batch.
func (*DB) ReverseIterator ¶
ReverseIterator returns a reverse iterator over the range [start, end).
func (*DB) SetMaintenancePhase ¶ added in v0.4.0
func (db *DB) SetMaintenancePhase(phase MaintenancePhase)
func (*DB) SetSync ¶
SetSync writes a key/value pair and forces a durability boundary. With DurabilityWALOnRelaxed or DurabilityWALOffRelaxed enabled, Sync operations are crash-consistent only (no fsync) and may not survive power loss.
func (*DB) VacuumIndexOnline ¶
VacuumIndexOnline rebuilds the user index into a new file and swaps it in with a short writer pause. Disk space from the old index is reclaimed once any old snapshots/iterators drain.
func (*DB) ValueLogGC ¶ added in v0.3.0
func (db *DB) ValueLogGC(ctx context.Context, opts ValueLogGCOptions) (ValueLogGCStats, error)
ValueLogGC deletes fully-unreferenced value-log segments.
In cached mode, strict mode checkpoints first. Online mode avoids a global checkpoint and protects retained value-log segments; if no protection data is available, it fails closed to dry-run.
func (*DB) ValueLogRewriteOnline ¶ added in v0.4.0
func (db *DB) ValueLogRewriteOnline(ctx context.Context, opts ValueLogRewriteOnlineOptions) (ValueLogRewriteStats, error)
ValueLogRewriteOnline rewrites pointer-backed values in bounded commit batches and atomically swaps keys to rewritten pointers.
In cached mode this method checkpoints first to establish a stable backend baseline before running online rewrite against the backend DB.
type DictLookup ¶ added in v0.3.0
type DictLookup = valuelog.DictLookup
type DurabilityMode ¶ added in v0.3.0
type DurabilityMode = db.DurabilityMode
type IntegrityMode ¶ added in v0.3.0
type IntegrityMode = db.IntegrityMode
type Iterator ¶
type Iterator interface {
Valid() bool
Next()
Key() []byte
Value() []byte
KeyCopy(dst []byte) []byte
ValueCopy(dst []byte) []byte
Close() error
Error() error
}
Iterator is the public iterator contract returned by TreeDB.
Semantics (performance-first; callers must treat slices as read-only):
- Key() and Value() return views valid until the next Next()/Close().
- Use KeyCopy/ValueCopy if you need stable bytes.
Example ¶
package main
import (
"fmt"
"os"
treedb "github.com/snissn/gomap/TreeDB"
)
func main() {
dir, err := os.MkdirTemp("", "treedb-iter-example-")
if err != nil {
panic(err)
}
defer os.RemoveAll(dir)
db, err := treedb.Open(treedb.Options{Dir: dir})
if err != nil {
panic(err)
}
defer db.Close()
// Insert keys in random order
db.SetSync([]byte("b"), []byte("2"))
db.SetSync([]byte("a"), []byte("1"))
db.SetSync([]byte("c"), []byte("3"))
// Iterate over all keys
it, err := db.Iterator(nil, nil)
if err != nil {
panic(err)
}
defer it.Close()
for ; it.Valid(); it.Next() {
fmt.Printf("%s: %s\n", it.Key(), it.Value())
}
}
Output: a: 1 b: 2 c: 3
type LeafGenerationGCOptions ¶ added in v0.5.0
type LeafGenerationGCOptions struct {
DryRun bool
}
LeafGenerationGCOptions controls whole-generation leaf-log garbage collection.
type LeafGenerationGCStats ¶ added in v0.5.0
type LeafGenerationGCStats struct {
GenerationsTotal int
GenerationsWritable int
GenerationsLive int
GenerationsRetiring int
GenerationsEligible int
GenerationsDeleted int
FilesDeleted int
}
LeafGenerationGCStats summarizes whole-generation leaf-log GC work.
type LeafGenerationPackFromPlanOptions ¶ added in v0.5.0
type LeafGenerationPackFromPlanOptions = treedbdb.LeafGenerationPackFromPlanOptions
LeafGenerationPackFromPlanOptions combines planner thresholds, bounded selection limits, and pack execution settings for the manual from-plan path.
type LeafGenerationPackOptions ¶ added in v0.5.0
type LeafGenerationPackOptions = treedbdb.LeafGenerationPackOptions
LeafGenerationPackOptions selects sealed source generations for explicit leaf-page compaction.
type LeafGenerationPackRunOnceStats ¶ added in v0.5.0
type LeafGenerationPackRunOnceStats = treedbdb.LeafGenerationPackRunOnceStats
LeafGenerationPackRunOnceStats describes one bounded admission/evaluation pass for leaf-generation packing.
type LeafGenerationPackSelectOptions ¶ added in v0.5.0
type LeafGenerationPackSelectOptions = treedbdb.LeafGenerationPackSelectOptions
LeafGenerationPackSelectOptions bounds a selected prefix of plan candidates.
type LeafGenerationPackSelection ¶ added in v0.5.0
type LeafGenerationPackSelection = treedbdb.LeafGenerationPackSelection
LeafGenerationPackSelection summarizes a bounded prefix of pack candidates.
func SelectLeafGenerationPackCandidates ¶ added in v0.5.0
func SelectLeafGenerationPackCandidates(plan LeafGenerationPlan, opts LeafGenerationPackSelectOptions) (LeafGenerationPackSelection, error)
SelectLeafGenerationPackCandidates selects a bounded prefix from an eligible leaf-generation plan. This is a pure helper for operator tooling and future bounded online maintenance runners.
type LeafGenerationPackStats ¶ added in v0.5.0
type LeafGenerationPackStats = treedbdb.LeafGenerationPackStats
LeafGenerationPackStats summarizes explicit leaf-generation pack work.
type LeafGenerationPlan ¶ added in v0.5.0
type LeafGenerationPlan = treedbdb.LeafGenerationPlan
LeafGenerationPlan summarizes explicit leaf-pack candidate generations.
type LeafGenerationPlanGeneration ¶ added in v0.5.0
type LeafGenerationPlanGeneration = treedbdb.LeafGenerationPlanGeneration
LeafGenerationPlanGeneration describes one manifest generation's current live and reclaim geometry.
type LeafGenerationPlanOptions ¶ added in v0.5.0
type LeafGenerationPlanOptions = treedbdb.LeafGenerationPlanOptions
LeafGenerationPlanOptions controls leaf-generation sparse-pack planning.
type MaintenancePhase ¶ added in v0.4.0
type MaintenancePhase = caching.MaintenancePhase
type Options ¶
Options configures TreeDB. It is re-exported from TreeDB/db for convenience.
func OptionsFor ¶
OptionsFor returns a copy of Options pre-filled for the given Profile.
The returned Options still follow TreeDB's normal defaulting rules for fields left as zero values (e.g. ChunkSize, KeepRecent, backpressure thresholds).
type Profile ¶
type Profile string
Profile is a documented, high-level preset for TreeDB Options.
Why profiles exist ------------------ TreeDB exposes many low-level knobs because different workloads want different trade-offs (durability vs throughput, steady-state vs benchmark determinism, background maintenance vs predictable latency).
In practice, most callers want one of a small number of "bundles":
- "Durable": the safest defaults; favors crash-recovery and integrity.
- "Fast": higher throughput by relaxing durability/integrity knobs.
- "Bench": a deterministic variant intended for benchmarking; disables background workers that can otherwise inject "random" work (e.g. index vacuum firing mid-run).
Profiles are intentionally conservative:
- They set the *meaningful policy knobs* (durability/integrity/background), while leaving the many throughput/capacity tuning knobs at their usual defaults.
- They do not require TreeDB internals to infer "intent" from combinations of flags. You pick the intent explicitly.
How to use ----------
New DB (recommended): opts := treedb.OptionsFor(treedb.ProfileDurable, "/path/to/db") opts.FlushThreshold = 128 << 20 // optional tuning db, err := treedb.Open(opts)
Existing Options (merge without clobbering explicit overrides): opts := treedb.Options{Dir: "/path/to/db"} treedb.ApplyProfile(&opts, treedb.ProfileBench) opts.FlushThreshold = 64 << 20 // explicit overrides always win db, err := treedb.Open(opts)
Note: Profiles are a convenience API. TreeDB still honors the established "0 uses a default; <0 disables" convention for background knobs, and callers can always override any field directly after applying a profile.
const ( // ProfileDurable is the recommended default for production use when you care // about durability and corruption detection. // // It keeps WAL and checksums enabled and leaves background maintenance at // their default settings. ProfileDurable Profile = "durable" // ProfileFast prioritizes throughput by relaxing durability/integrity knobs. // // This profile is appropriate when: // - you are running on top of an external durability boundary (e.g. you // snapshot at higher layers), or // - you are exploring performance limits, and crashes/corruption detection // are acceptable trade-offs. // // Background maintenance is left enabled by default; it is generally helpful // for keeping the index compact and read-friendly. ProfileFast Profile = "fast" // ProfileWALOnFast is a "WAL on + relaxed durability" profile intended for // write-heavy benchmarks and ingest workloads. // // It keeps WAL enabled but disables fsync and value-log read checksums. ProfileWALOnFast Profile = "wal_on_fast" // ProfileBench is a "fast + deterministic" profile intended specifically for // benchmarking. // // It disables background workers that can inject heavy work mid-run (e.g. // background index vacuum). This makes comparisons more stable across runs. // // IMPORTANT: This is not a recommended production profile. ProfileBench Profile = "bench" )
type Snapshot ¶
type Snapshot interface {
Pager() *pager.Pager
State() *backenddb.DBState
Get(key []byte) ([]byte, error)
GetAppend(key, dst []byte) ([]byte, error)
GetUnsafe(key []byte) ([]byte, error)
Has(key []byte) (bool, error)
GetEntry(key []byte) (node.LeafEntry, error)
GetEntryExact(key []byte) (node.LeafEntry, error)
Close() error
}
Snapshot is a consistent point-in-time view of the database.
In cached mode, snapshots include writes that are buffered in memtables.
TreeDB is pre-alpha; this interface may change without notice.
type TrainConfig ¶ added in v0.3.0
type TrainConfig = compression.TrainConfig
Dictionary training/lookup helpers for value-log compression.
type ValueLogAutoPolicy ¶ added in v0.3.0
type ValueLogAutoPolicy = db.ValueLogAutoPolicy
type ValueLogBlockCodec ¶ added in v0.3.0
type ValueLogBlockCodec = db.ValueLogBlockCodec
type ValueLogCompressionMode ¶ added in v0.3.0
type ValueLogCompressionMode = db.ValueLogCompressionMode
type ValueLogDictClassMode ¶ added in v0.4.0
type ValueLogDictClassMode = db.ValueLogDictClassMode
type ValueLogDomainThreshold ¶ added in v0.4.0
type ValueLogDomainThreshold = db.ValueLogDomainThreshold
type ValueLogGCMode ¶ added in v0.4.0
type ValueLogGCMode string
ValueLogGCMode controls cached-mode coordination for value-log GC.
Pre-alpha note: "online" currently uses retained-path protection and may fail closed to dry-run when protection data is unavailable.
const ( ValueLogGCModeStrict ValueLogGCMode = "strict" ValueLogGCModeOnline ValueLogGCMode = "online" )
type ValueLogGCOptions ¶ added in v0.3.0
type ValueLogGCOptions struct {
DryRun bool
// Mode controls cached-mode behavior. Empty defaults to "strict".
Mode ValueLogGCMode
}
ValueLogGCOptions controls value-log garbage collection.
type ValueLogGCStats ¶ added in v0.3.0
type ValueLogGCStats struct {
SegmentsTotal int
SegmentsReferenced int
SegmentsActive int
SegmentsProtected int
SegmentsEligible int
SegmentsDeleted int
BytesTotal int64
BytesReferenced int64
BytesActive int64
BytesProtected int64
BytesEligible int64
BytesDeleted int64
// FailClosedToDryRun reports that online mode intentionally converted the
// operation to a dry-run for safety.
FailClosedToDryRun bool
}
ValueLogGCStats summarizes value-log GC work.
type ValueLogGenerationConfig ¶ added in v0.4.0
type ValueLogGenerationConfig = db.ValueLogGenerationConfig
type ValueLogGenerationPolicy ¶ added in v0.4.0
type ValueLogGenerationPolicy = db.ValueLogGenerationPolicy
type ValueLogOptions ¶ added in v0.3.0
type ValueLogOptions = db.ValueLogOptions
type ValueLogRewriteLocalityPolicy ¶ added in v0.4.0
type ValueLogRewriteLocalityPolicy = treedbdb.ValueLogRewriteLocalityPolicy
ValueLogRewriteLocalityPolicy controls pointer rewrite ordering.
type ValueLogRewriteOnlineOptions ¶ added in v0.4.0
type ValueLogRewriteOnlineOptions = treedbdb.ValueLogRewriteOnlineOptions
ValueLogRewriteOnlineOptions controls online rewrite batching behavior.
type ValueLogRewriteStats ¶ added in v0.3.0
type ValueLogRewriteStats = treedbdb.ValueLogRewriteStats
ValueLogRewriteStats summarizes value-log rewrite compaction results.
func ValueLogRewriteOffline ¶ added in v0.3.0
func ValueLogRewriteOffline(opts Options) (ValueLogRewriteStats, error)
ValueLogRewriteOffline rewrites value-log pointers into new segments and swaps index.db to reference the new log. This is an offline operation that requires an exclusive lock and a clean commitlog.
type ZSTDEncoderLevel ¶ added in v0.3.0
type ZSTDEncoderLevel = zstd.EncoderLevel
Zstd encoder levels (for dict-compressed value-log frames).
Source Files
¶
- bg_vacuum.go
- dir_layout.go
- doc.go
- errors.go
- leaf_generation_gc.go
- leaf_generation_pack.go
- leaf_generation_pack_from_plan.go
- leaf_generation_pack_run_once.go
- leaf_generation_pack_select.go
- leaf_generation_plan.go
- open_backend.go
- options_aliases.go
- profiles.go
- public.go
- side_store_lookups.go
- snapshot.go
- template_adapter.go
- value_log_dict_compression.go
- vlog_gc.go
- vlog_rewrite.go
Directories
¶
| Path | Synopsis |
|---|---|
|
cmd
|
|
|
db_histogram
command
|
|
|
debug_open
command
|
|
|
stress
command
|
|
|
template_corpus_extract
command
|
|
|
template_lab
command
|
|
|
template_seed_train
command
|
|
|
treemap
command
|
|
|
unified_bench
command
|
|
|
verify
command
|
|
|
vlog_codec_shape_sweep
command
|
|
|
vlog_dict_realdata
command
|
|
|
wal_classify
command
|
|
|
internal
|
|