Documentation ¶
Index ¶
- func ResponseHandler(w http.ResponseWriter, r *http.Request, data []byte)
- type Batch
- type DB
- func (db *DB) All(f func(timeID int64, keys []uint64) (bool, error)) (err error)
- func (db *DB) Batch(fn func(*Batch, <-chan struct{}) error) error
- func (db *DB) BlockIterator(f func(timeID int64, keys []uint64) (bool, error)) (err error)
- func (db *DB) Close() error
- func (db *DB) Delete(key uint64) error
- func (db *DB) Free(timeID int64) error
- func (db *DB) Get(key uint64) ([]byte, error)
- func (db *DB) HandleVarz(w http.ResponseWriter, r *http.Request)
- func (db *DB) Keys() []uint64
- func (db *DB) Lookup(timeID int64, key uint64) ([]byte, error)
- func (db *DB) NewBatch() *Batch
- func (db *DB) Put(key uint64, data []byte) (int64, error)
- func (db *DB) Size() int64
- func (db *DB) Varz() (*Varz, error)
- type Meter
- type Options
- type Varz
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func ResponseHandler ¶
func ResponseHandler(w http.ResponseWriter, r *http.Request, data []byte)
ResponseHandler handles responses for monitoring routes.
Types ¶
type Batch ¶
type Batch struct {
// contains filtered or unexported fields
}
Batch is a write batch.
func (*Batch) Commit ¶
Commit commits changes to the DB. In batch operation commit is managed and client is not allowed to call Commit. On Commit complete batch operation signal to the caller if the batch is fully committed to DB.
type DB ¶
type DB struct {
// contains filtered or unexported fields
}
DB represents an SSD-optimized mem store.
func (*DB) Batch ¶
Batch executes a function within the context of a read-write managed transaction. If no error is returned from the function then the transaction is written. If an error is returned then the entire transaction is rolled back. Any error that is returned from the function or returned from the write is returned from the Batch() method.
Attempting to manually commit or rollback within the function will cause a panic.
func (*DB) BlockIterator ¶
BlockIterator iterates all time blocks from DB committed to the WAL.
func (*DB) Delete ¶
Delete deletes entry from the DB. It writes deleted key into new time block to persist record into the WAL. If all entries are deleted from a time block then the time block is released from the WAL.
func (*DB) HandleVarz ¶
func (db *DB) HandleVarz(w http.ResponseWriter, r *http.Request)
HandleVarz will process HTTP requests for unitdb stats information.
func (*DB) NewBatch ¶
NewBatch returns unmanaged Batch so caller can perform Put, Write, Commit, Abort to the Batch.
type Meter ¶
type Meter struct { Metrics metrics.Metrics TimeSeries metrics.TimeSeries Gets metrics.Counter Puts metrics.Counter Syncs metrics.Counter Recovers metrics.Counter Dels metrics.Counter }
Meter meter provides various db statistics.
func (*Meter) UnregisterAll ¶
func (m *Meter) UnregisterAll()
UnregisterAll unregister all metrics from meter.
type Options ¶
type Options interface {
// contains filtered or unexported methods
}
Options it contains configurable options and flags for DB.
func WithBufferSize ¶
WithBufferSize sets max size of buffer to use for buffer pooling.
func WithDefaultOptions ¶
func WithDefaultOptions() Options
WithDefaultOptions will open DB with some default values.
func WithLogFilePath ¶
WithLogFilePath sets database directory for storing logs.
func WithLogInterval ¶
WithLogInterval sets interval for a time block. Block is pushed to the queue to write it to the log file.
func WithLogReset ¶
func WithLogReset() Options
WithLogReset flag to skip recovery on DB open and reset WAL.
func WithTimeBlockInterval ¶
WithTimeBlockInterval sets interval for a time block. Block is pushed to the queue to write it to the log file.
type Varz ¶
type Varz struct { Start time.Time `json:"start"` Now time.Time `json:"now"` Uptime string `json:"uptime"` Count int64 `json:"count"` Gets int64 `json:"gets"` Puts int64 `json:"puts"` Syncs int64 `json:"syncs"` Recovers int64 `json:"recovers"` Dels int64 `json:"Dels"` HMean float64 `json:"hmean"` // Event duration harmonic mean. P50 float64 `json:"p50"` // Event duration nth percentiles. P75 float64 `json:"p75"` P95 float64 `json:"p95"` P99 float64 `json:"p99"` P999 float64 `json:"p999"` Long5p float64 `json:"long_5p"` // Average of the longest 5% event durations. Short5p float64 `json:"short_5p"` // Average of the shortest 5% event durations. Max float64 `json:"max"` // Highest event duration. Min float64 `json:"min"` // Lowest event duration. StdDev float64 `json:"stddev"` // Standard deviation. }
Varz outputs memdb stats on the monitoring port at /varz.