| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 |
- package storage
- import (
- "io"
- "github.com/coreos/etcd/storage/storagepb"
- )
- // CancelFunc tells an operation to abandon its work. A CancelFunc does not
- // wait for the work to stop.
- type CancelFunc func()
- type KV interface {
- // Range gets the keys in the range at rangeRev.
- // If rangeRev <=0, range gets the keys at currentRev.
- // If `end` is nil, the request returns the key.
- // If `end` is not nil, it gets the keys in range [key, range_end).
- // Limit limits the number of keys returned.
- // If the required rev is compacted, ErrCompacted will be returned.
- Range(key, end []byte, limit, rangeRev int64) (kvs []storagepb.KeyValue, rev int64, err error)
- // Put puts the given key,value into the store.
- // A put also increases the rev of the store, and generates one event in the event history.
- Put(key, value []byte) (rev int64)
- // DeleteRange deletes the given range from the store.
- // A deleteRange increases the rev of the store if any key in the range exists.
- // The number of key deleted will be returned.
- // It also generates one event for each key delete in the event history.
- // if the `end` is nil, deleteRange deletes the key.
- // if the `end` is not nil, deleteRange deletes the keys in range [key, range_end).
- DeleteRange(key, end []byte) (n, rev int64)
- // TxnBegin begins a txn. Only Txn prefixed operation can be executed, others will be blocked
- // until txn ends. Only one on-going txn is allowed.
- // TxnBegin returns an int64 txn ID.
- // All txn prefixed operations with same txn ID will be done with the same rev.
- TxnBegin() int64
- // TxnEnd ends the on-going txn with txn ID. If the on-going txn ID is not matched, error is returned.
- TxnEnd(txnID int64) error
- TxnRange(txnID int64, key, end []byte, limit, rangeRev int64) (kvs []storagepb.KeyValue, rev int64, err error)
- TxnPut(txnID int64, key, value []byte) (rev int64, err error)
- TxnDeleteRange(txnID int64, key, end []byte) (n, rev int64, err error)
- Compact(rev int64) error
- // Get the hash of KV state.
- // This method is designed for consistency checking purpose.
- Hash() (uint32, error)
- // Write a snapshot to the given io writer
- Snapshot(w io.Writer) (int64, error)
- Restore() error
- Close() error
- }
- // Watcher watches on the KV. It will be notified if there is an event
- // happened on the watched key or prefix.
- type Watcher interface {
- // Event returns a channel that receives observed event that matches the
- // context of watcher. When watch finishes or is canceled or aborted, the
- // channel is closed and returns empty event.
- // Successive calls to Event return the same value.
- Event() <-chan storagepb.Event
- // Err returns a non-nil error value after Event is closed. Err returns
- // Compacted if the history was compacted, Canceled if watch is canceled,
- // or EOF if watch reaches the end revision. No other values for Err are defined.
- // After Event is closed, successive calls to Err return the same value.
- Err() error
- }
- // WatchableKV is a KV that can be watched.
- type WatchableKV interface {
- KV
- // Watcher watches the events happening or happened in etcd. The whole
- // event history can be watched unless compacted.
- // If `prefix` is true, watch observes all events whose key prefix could be the given `key`.
- // If `startRev` <=0, watch observes events after currentRev.
- // If `endRev` <=0, watch observes events until watch is cancelled.
- //
- // Canceling the watcher releases resources associated with it, so code
- // should always call cancel as soon as watch is done.
- Watcher(key []byte, prefix bool, startRev, endRev int64) (Watcher, CancelFunc)
- }
|