Documentation ¶
Index ¶
- Constants
- Variables
- func GetShardKey(key string, i int) string
- func IsSetCacheError(err error) bool
- type Cache
- func (p *Cache[K, V]) Delete(ctx context.Context, pks ...K) error
- func (p *Cache[K, V]) Get(ctx context.Context, pk K) (V, error)
- func (p *Cache[K, V]) MGetMap(ctx context.Context, pks []K) (map[K]V, error)
- func (p *Cache[K, V]) MGetSlice(ctx context.Context, pks []K) ([]V, error)
- func (p *Cache[K, V]) MSetMap(ctx context.Context, models map[K]V, expiration time.Duration) error
- func (p *Cache[K, V]) MSetSlice(ctx context.Context, models []V, expiration time.Duration) error
- func (p *Cache[K, V]) Set(ctx context.Context, pk K, elem V, expiration time.Duration) error
- type CacheConfig
- type KVPair
- type Key
- type KeyFactory
- type Loader
- type Model
- type ShardingCache
- func (p *ShardingCache[K, V]) Delete(ctx context.Context, deleteAllShards bool, pks ...K) error
- func (p *ShardingCache[K, V]) Get(ctx context.Context, pk K) (V, error)
- func (p *ShardingCache[K, V]) MGetMap(ctx context.Context, pks []K) (result map[K]V, errMap map[K]error, storageErr error)
- func (p *ShardingCache[K, V]) MGetSlice(ctx context.Context, pks []K) (result []V, errMap map[K]error, storageErr error)
- func (p *ShardingCache[K, V]) MSetMap(ctx context.Context, models map[K]V, expiration time.Duration) error
- func (p *ShardingCache[K, V]) MSetSlice(ctx context.Context, models []V, expiration time.Duration) error
- func (p *ShardingCache[K, V]) Set(ctx context.Context, pk K, elem V, expiration time.Duration) error
- type ShardingCacheConfig
- type ShardingData
- type ShardingModel
- type Storage
Constants ¶
const DefaultBatchSize = 200
DefaultBatchSize is the default batch size for batch operations.
const DefaultLRUExpiration = time.Second
DefaultLRUExpiration is the default expiration time for data in LRU cache.
const DefaultLoaderBatchSize = 500
DefaultLoaderBatchSize is the default batch size for calling Loader.
Variables ¶
var ErrDataNotFound = errors.New("data not found")
Functions ¶
func GetShardKey ¶ added in v2.11.1
GetShardKey returns the shard key for given key and index of shard.
func IsSetCacheError ¶ added in v2.16.0
IsSetCacheError tells whether an error returned from this package is occurred when set data to underlying cache storage.
Types ¶
type Cache ¶
type Cache[K comparable, V Model] struct { // contains filtered or unexported fields }
Cache encapsulates frequently used batching cache operations, such as MGet, MSet and Delete.
A Cache must not be copied after initialized.
func NewCache ¶
func NewCache[K comparable, V Model](config *CacheConfig[K, V]) *Cache[K, V]
NewCache returns a new Cache instance.
func (*Cache[K, V]) Get ¶
Get queries Cache for a given pk.
If pk cannot be found either in the cache nor from the Loader, it returns an error ErrDataNotFound.
Error may occur during setting data to cache, while we do get data from Loader, in this case the returned value is valid, but the error is returned together with the value, user can use IsSetCacheError to check it.
func (*Cache[K, V]) MGetMap ¶
MGetMap queries Cache and returns the cached values as a map of type map[K]V. Note the returned values may be less than requested.
Error may occur during setting data to cache, while we do get data from Loader, in this case the returned value is valid, but the error is returned together with the value, user can use IsSetCacheError to check it. But for any error that IsSetCacheError returns false, the returned data is incomplete and shall not be used.
func (*Cache[K, V]) MGetSlice ¶
MGetSlice queries Cache and returns the cached values as a slice of type []V. Note the returned values may be less than requested.
Error may occur during setting data to cache, while we do get data from Loader, in this case the returned value is valid, but the error is returned together with the value, user can use IsSetCacheError to check it. But for any error that IsSetCacheError returns false, the returned data is incomplete and shall not be used.
type CacheConfig ¶
type CacheConfig[K comparable, V Model] struct { // Storage must return a Storage implementation which will be used // as the underlying key-value storage. Storage func(ctx context.Context) Storage // IDFunc returns the primary key of a Model object. IDFunc func(V) K // KeyFunc specifies the key function to use with the storage. KeyFunc Key // MGetBatchSize optionally specifies the batch size for one MGet // calling to storage. The default is 200. MGetBatchSize int // MSetBatchSize optionally specifies the batch size for one MSet // calling to storage. The default is 200. MSetBatchSize int // DeleteBatchSize optionally specifies the batch size for one Delete // calling to storage. The default is 200. DeleteBatchSize int // LRUCache optionally enables LRU cache, which may help to improve // the performance for high concurrency use-case. LRUCache lru.Interface[K, V] // LRUExpiration specifies the expiration time for data in LRU cache. // The default is one second. LRUExpiration time.Duration // Loader optionally specifies a function to load data from underlying // persistent storage when the data is missing from cache. Loader Loader[K, V] // LoaderBatchSize optionally specifies the batch size for calling // Loader. The default is 500. LoaderBatchSize int // CacheExpiration specifies the expiration time to cache the data to // Storage, when Loader is configured and data are loaded by Loader. // The default is zero, which means no expiration. CacheExpiration time.Duration // CacheLoaderResultAsync makes the Cache to save data from Loader // to Storage async, errors returned from Storage.MSet will be ignored. // The default is false, it reports errors to the caller. CacheLoaderResultAsync bool }
CacheConfig configures a Cache instance.
type KeyFactory ¶ added in v2.11.0
type KeyFactory struct {
// contains filtered or unexported fields
}
KeyFactory builds Key functions.
func (*KeyFactory) NewKey ¶ added in v2.11.0
func (kf *KeyFactory) NewKey(format string, argNames ...string) Key
NewKey creates a Key function.
If argNames are given (eg. arg1, arg2), it replace the placeholders of `{argN}` in format to "%v" as key arguments, else it uses a regular expression `\{[^{]*\}` to replace all placeholders of `{arg}` in format to "%v" as key arguments.
func (*KeyFactory) SetPrefix ¶ added in v2.11.0
func (kf *KeyFactory) SetPrefix(prefix string)
SetPrefix configures the Key functions created by the factory to add a prefix to all generated cache keys.
type Loader ¶
type Loader[K comparable, V Model] func(ctx context.Context, pks []K) (map[K]V, error)
Loader loads data from underlying persistent storage.
type Model ¶
type Model interface { encoding.BinaryMarshaler encoding.BinaryUnmarshaler }
Model is the interface implemented by types that can be cached by Cache.
type ShardingCache ¶ added in v2.11.1
type ShardingCache[K comparable, V ShardingModel] struct { // contains filtered or unexported fields }
ShardingCache implements common cache operations for big cache value, it helps to split big value into shards according to ShardingCacheConfig.ShardingSize.
When saving data to cache storage, it checks length of the serialization result, if it does not exceed ShardingSize, it saves one key-value to storage, else it splits the serialization result to multiple shards and saves multiple key-values to storage.
When doing query, it first loads the first shard from storage and checks whether there are more shards, if yes, it builds the keys of other shards using the information in the first shard, then reads the other shards, and concat all data to deserialize the complete model.
A ShardingCache must not be copied after initialization.
func NewShardingCache ¶ added in v2.11.1
func NewShardingCache[K comparable, V ShardingModel](config *ShardingCacheConfig[K, V]) *ShardingCache[K, V]
NewShardingCache returns a new ShardingCache instance.
func (*ShardingCache[K, V]) Delete ¶ added in v2.11.1
func (p *ShardingCache[K, V]) Delete(ctx context.Context, deleteAllShards bool, pks ...K) error
Delete deletes key values from ShardingCache.
By default, it only deletes the first shards from storage, if the underlying storage is Redis, the other shards shall be evicted when they are expired. If the underlying storage does not support auto eviction, or the data does not expire, or user want to release storage space actively, deleteAllShards should be set to true, which indicates it to read the first shard from storage and checks whether there are more shards, it yes, it builds the keys of other shards using the information in the first shard, then deletes all shards from storage.
func (*ShardingCache[K, V]) Get ¶ added in v2.11.1
func (p *ShardingCache[K, V]) Get(ctx context.Context, pk K) (V, error)
Get queries ShardingCache for a given pk.
If pk cannot be found in the cache, it returns an error ErrDataNotFound.
func (*ShardingCache[K, V]) MGetMap ¶ added in v2.16.0
func (p *ShardingCache[K, V]) MGetMap(ctx context.Context, pks []K) ( result map[K]V, errMap map[K]error, storageErr error)
MGetMap queries ShardingCache for multiple pks and returns the cached values as a map of type map[K]V. Note the returned values may be less than requested.
func (*ShardingCache[K, V]) MGetSlice ¶ added in v2.16.0
func (p *ShardingCache[K, V]) MGetSlice(ctx context.Context, pks []K) ( result []V, errMap map[K]error, storageErr error)
MGetSlice queries ShardingCache for multiple pks and returns the cached values as a slice of type []V. Note the returned values may be less than requested.
func (*ShardingCache[K, V]) MSetMap ¶ added in v2.16.0
func (p *ShardingCache[K, V]) MSetMap(ctx context.Context, models map[K]V, expiration time.Duration) error
MSetMap serializes and writes multiple models to ShardingCache.
type ShardingCacheConfig ¶ added in v2.11.1
type ShardingCacheConfig[K comparable, V ShardingModel] struct { // Storage must return a Storage implementation which will be used // as the underlying key-value storage. Storage func(ctx context.Context) Storage // IDFunc returns the primary key of a ShardingModel object. IDFunc func(V) K // KeyFunc specifies the key function to use with the storage. KeyFunc Key // ShardingSize configures the maximum length of data in a shard. // When the serialization result of V is longer than ShardingSize, // the data will be split into shards to save to storage. // // ShardingSize must be greater than zero, else it panics. ShardingSize int // MGetBatchSize optionally specifies the batch size for one MGet // calling to storage. The default is 200. MGetBatchSize int // MSetBatchSize optionally specifies the batch size for one MSet // calling to storage. The default is 200. MSetBatchSize int // DeleteBatchSize optionally specifies the batch size for one Delete // calling to storage. The default is 200. DeleteBatchSize int }
ShardingCacheConfig configures a ShardingCache instance.
type ShardingData ¶ added in v2.11.1
type ShardingData struct { TotalNum int32 `protobuf:"varint,1,opt,name=total_num,json=totalNum,proto3" json:"total_num,omitempty"` ShardNum int32 `protobuf:"varint,2,opt,name=shard_num,json=shardNum,proto3" json:"shard_num,omitempty"` Digest []byte `protobuf:"bytes,3,opt,name=digest,proto3" json:"digest,omitempty"` Data []byte `protobuf:"bytes,4,opt,name=data,json=data,proto3" json:"data,omitempty"` }
ShardingData holds sharding information and partial data of a sharding.
Example:
// protobuf message ShardingData { int32 total_num = 1; int32 shard_num = 2; bytes digest = 3; bytes data = 4; }
type ShardingModel ¶ added in v2.11.1
type ShardingModel interface { Model // GetShardingData returns whether a model is a shard or a complete model. // When the returned bool value is true, the returned ShardingData // can be a zero value, and shall not be used. GetShardingData() (data ShardingData, isShard bool) // SetShardingData sets a shard data to a new model created when // doing serialization to split data into shards and save to storage. SetShardingData(data ShardingData) }
ShardingModel is the interface implemented by types that can be cached by ShardingCache.
A ShardingModel implementation type should save ShardingData with it, and can tell whether it's a shard or a complete model.
type Storage ¶
type Storage interface { MGet(ctx context.Context, keys ...string) ([][]byte, error) MSet(ctx context.Context, kvPairs []KVPair, expiration time.Duration) error Delete(ctx context.Context, keys ...string) error }
Storage is the interface which provides storage for Cache. Users may use any key-value storage to implement this.