mirror of
				https://github.com/etcd-io/etcd.git
				synced 2024-09-27 06:25:44 +00:00 
			
		
		
		
	 ba9a46aa02
			
		
	
	
		ba9a46aa02
		
	
	
	
	
		
			
			Snapshot takes an io.Writer and writes the entire backend data to the given writer. Snapshot writes a consistent view and does not block other storage operations. Restore restores the in-memory states (index and book keeping) of the storage from the backend data.
		
			
				
	
	
		
			49 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			49 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package storage
 | |
| 
 | |
| import (
 | |
| 	"io"
 | |
| 
 | |
| 	"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
 | |
| 
 | |
| 	// Write a snapshot to the given io writer
 | |
| 	Snapshot(w io.Writer) (int64, error)
 | |
| 
 | |
| 	Restore() error
 | |
| 	Close() error
 | |
| }
 |