Documentation ¶
Index ¶
- Variables
- type BoltStore
- func (b *BoltStore) Close() error
- func (b *BoltStore) DeleteRange(min, max uint64) error
- func (b *BoltStore) FirstIndex() (uint64, error)
- func (b *BoltStore) Get(k []byte) ([]byte, error)
- func (b *BoltStore) GetLog(idx uint64, log *raft.Log) error
- func (b *BoltStore) GetUint64(key []byte) (uint64, error)
- func (b *BoltStore) LastIndex() (uint64, error)
- func (b *BoltStore) RunMetrics(ctx context.Context, interval time.Duration)
- func (b *BoltStore) Set(k, v []byte) error
- func (b *BoltStore) SetUint64(key []byte, val uint64) error
- func (b *BoltStore) Stats() bbolt.Stats
- func (b *BoltStore) StoreLog(log *raft.Log) error
- func (b *BoltStore) StoreLogs(logs []*raft.Log) error
- func (b *BoltStore) Sync() error
- type Options
Constants ¶
This section is empty.
Variables ¶
var ( // An error indicating a given key does not exist ErrKeyNotFound = errors.New("not found") )
Functions ¶
This section is empty.
Types ¶
type BoltStore ¶
type BoltStore struct {
// contains filtered or unexported fields
}
BoltStore provides access to Bbolt for Raft to store and retrieve log entries. It also provides key/value storage, and can be used as a LogStore and StableStore.
func MigrateToV2 ¶
MigrateToV2 reads in the source file path of a BoltDB file and outputs all the data migrated to a Bbolt destination file
func New ¶
New uses the supplied options to open the Bbolt and prepare it for use as a raft backend.
func NewBoltStore ¶
NewBoltStore takes a file path and returns a connected Raft backend.
func (*BoltStore) DeleteRange ¶
DeleteRange is used to delete logs within a given range inclusively.
func (*BoltStore) FirstIndex ¶
FirstIndex returns the first known index from the Raft log.
func (*BoltStore) RunMetrics ¶
RunMetrics should be executed in a go routine and will periodically emit metrics on the given interval until the context has been cancelled.
type Options ¶
type Options struct { // Path is the file path to the Bbolt to use Path string // BoltOptions contains any specific Bbolt options you might // want to specify [e.g. open timeout] BoltOptions *bbolt.Options // NoSync causes the database to skip fsync calls after each // write to the log. This is unsafe, so it should be used // with caution. NoSync bool // MsgpackUseNewTimeFormat when set to true, force the underlying msgpack // codec to use the new format of time.Time when encoding (used in // go-msgpack v1.1.5 by default). Decoding is not affected, as all // go-msgpack v2.1.0+ decoders know how to decode both formats. MsgpackUseNewTimeFormat bool }
Options contains all the configuration used to open the Bbolt