mirror of
https://github.com/etcd-io/etcd.git
synced 2024-09-27 06:25:44 +00:00
39 lines
1.8 KiB
Go
39 lines
1.8 KiB
Go
package storage
|
|
|
|
import "github.com/coreos/etcd/storage/storagepb"
|
|
|
|
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)
|
|
|
|
// TnxBegin begins a tnx. Only Tnx prefixed operation can be executed, others will be blocked
|
|
// until tnx ends. Only one on-going tnx is allowed.
|
|
// TnxBegin returns an int64 tnx ID.
|
|
// All tnx prefixed operations with same tnx ID will be done with the same rev.
|
|
TnxBegin() int64
|
|
// TnxEnd ends the on-going tnx with tnx ID. If the on-going tnx ID is not matched, error is returned.
|
|
TnxEnd(tnxID int64) error
|
|
TnxRange(tnxID int64, key, end []byte, limit, rangeRev int64) (kvs []storagepb.KeyValue, rev int64, err error)
|
|
TnxPut(tnxID int64, key, value []byte) (rev int64, err error)
|
|
TnxDeleteRange(tnxID int64, key, end []byte) (n, rev int64, err error)
|
|
|
|
Compact(rev int64) error
|
|
}
|