kv.go 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. // Copyright 2015 The etcd Authors
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. package mvcc
  15. import (
  16. "github.com/coreos/etcd/lease"
  17. "github.com/coreos/etcd/mvcc/backend"
  18. "github.com/coreos/etcd/mvcc/mvccpb"
  19. )
  20. type RangeOptions struct {
  21. Limit int64
  22. Rev int64
  23. Count bool
  24. }
  25. type RangeResult struct {
  26. KVs []mvccpb.KeyValue
  27. Rev int64
  28. Count int
  29. }
  30. type KV interface {
  31. // Rev returns the current revision of the KV.
  32. Rev() int64
  33. // FirstRev returns the first revision of the KV.
  34. // After a compaction, the first revision increases to the compaction
  35. // revision.
  36. FirstRev() int64
  37. // Range gets the keys in the range at rangeRev.
  38. // The returned rev is the current revision of the KV when the operation is executed.
  39. // If rangeRev <=0, range gets the keys at currentRev.
  40. // If `end` is nil, the request returns the key.
  41. // If `end` is not nil and not empty, it gets the keys in range [key, range_end).
  42. // If `end` is not nil and empty, it gets the keys greater than or equal to key.
  43. // Limit limits the number of keys returned.
  44. // If the required rev is compacted, ErrCompacted will be returned.
  45. Range(key, end []byte, ro RangeOptions) (r *RangeResult, err error)
  46. // Put puts the given key, value into the store. Put also takes additional argument lease to
  47. // attach a lease to a key-value pair as meta-data. KV implementation does not validate the lease
  48. // id.
  49. // A put also increases the rev of the store, and generates one event in the event history.
  50. // The returned rev is the current revision of the KV when the operation is executed.
  51. Put(key, value []byte, lease lease.LeaseID) (rev int64)
  52. // DeleteRange deletes the given range from the store.
  53. // A deleteRange increases the rev of the store if any key in the range exists.
  54. // The number of key deleted will be returned.
  55. // The returned rev is the current revision of the KV when the operation is executed.
  56. // It also generates one event for each key delete in the event history.
  57. // if the `end` is nil, deleteRange deletes the key.
  58. // if the `end` is not nil, deleteRange deletes the keys in range [key, range_end).
  59. DeleteRange(key, end []byte) (n, rev int64)
  60. // TxnBegin begins a txn. Only Txn prefixed operation can be executed, others will be blocked
  61. // until txn ends. Only one on-going txn is allowed.
  62. // TxnBegin returns an int64 txn ID.
  63. // All txn prefixed operations with same txn ID will be done with the same rev.
  64. TxnBegin() int64
  65. // TxnEnd ends the on-going txn with txn ID. If the on-going txn ID is not matched, error is returned.
  66. TxnEnd(txnID int64) error
  67. // TxnRange returns the current revision of the KV when the operation is executed.
  68. TxnRange(txnID int64, key, end []byte, ro RangeOptions) (r *RangeResult, err error)
  69. TxnPut(txnID int64, key, value []byte, lease lease.LeaseID) (rev int64, err error)
  70. TxnDeleteRange(txnID int64, key, end []byte) (n, rev int64, err error)
  71. // Compact frees all superseded keys with revisions less than rev.
  72. Compact(rev int64) (<-chan struct{}, error)
  73. // Hash retrieves the hash of KV state and revision.
  74. // This method is designed for consistency checking purpose.
  75. Hash() (hash uint32, revision int64, err error)
  76. // Commit commits txns into the underlying backend.
  77. Commit()
  78. // Restore restores the KV store from a backend.
  79. Restore(b backend.Backend) error
  80. Close() error
  81. }
  82. // WatchableKV is a KV that can be watched.
  83. type WatchableKV interface {
  84. KV
  85. Watchable
  86. }
  87. // Watchable is the interface that wraps the NewWatchStream function.
  88. type Watchable interface {
  89. // NewWatchStream returns a WatchStream that can be used to
  90. // watch events happened or happening on the KV.
  91. NewWatchStream() WatchStream
  92. }
  93. // ConsistentWatchableKV is a WatchableKV that understands the consistency
  94. // algorithm and consistent index.
  95. // If the consistent index of executing entry is not larger than the
  96. // consistent index of ConsistentWatchableKV, all operations in
  97. // this entry are skipped and return empty response.
  98. type ConsistentWatchableKV interface {
  99. WatchableKV
  100. // ConsistentIndex returns the current consistent index of the KV.
  101. ConsistentIndex() uint64
  102. }