Documentation ¶
Overview ¶
Package objcache transcodes arbitrary Go types to bytes and stores them in a cache reducing GC.
A Cache can be either in memory or a persistent one. Cache adapters are available for bigcache or Redis. To enable the cache adapter use build tags "bigcache" or "redis" or "csall". More cache adapters might follow.
Use case: Caching millions of Go types as a byte slice reduces the pressure to the GC.
For more details regarding bigcache: https://godoc.org/github.com/allegro/bigcache
Index ¶
- func MakeBinary() binary
- type Codecer
- type Decoder
- type Encoder
- type LRUOptions
- type NewStorageFn
- type Service
- func (tr *Service) Close() error
- func (tr *Service) Delete(ctx context.Context, key ...string) error
- func (tr *Service) Get(ctx context.Context, key string, dst interface{}) (err error)
- func (tr *Service) GetMulti(ctx context.Context, keys []string, dst []interface{}) (err error)
- func (tr *Service) Set(ctx context.Context, key string, src interface{}, expires time.Duration) error
- func (tr *Service) SetMulti(ctx context.Context, keys []string, src []interface{}, expires []time.Duration) error
- func (tr *Service) Truncate(ctx context.Context) (err error)
- type ServiceOptions
- type Storager
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func MakeBinary ¶
func MakeBinary() binary
MakeBinary creates a binary type for using in Set/Get functions when the code needs a `set` algorithm. For example checking if a JWT exists in the blacklist. Function IsValid returns true if the key exists.
Types ¶
type Decoder ¶
type Decoder interface {
Decode(dst interface{}) error
}
Decoder defines how to decode a byte slice into variable dst. Please see option function WithEncoder() for details how to get the byte slice.
type Encoder ¶
type Encoder interface {
Encode(src interface{}) error
}
Encoder defines how to Encode a type represented by variable src into a byte slice. Encoders must write their data into an io.Writer defined in option function WithEncoder().
type LRUOptions ¶
type LRUOptions struct { Capacity int64 // default 5000 objects TrackBySize bool TrackByObjectCount bool // default LRUCache *lru.LRUCache }
LRUOptions allows to track the cache items either by object count or total size in bytes. If tracking by `TrackBySize` gets enabled then `Capacity` must have the value in bytes. Default 64MB.
type NewStorageFn ¶
func NewBlackHoleClient ¶
func NewBlackHoleClient(optionalTestErr error) NewStorageFn
NewBlackHoleClient creates a black hole client for testing with the ability to return errors.
func NewLRU ¶
func NewLRU(o *LRUOptions) NewStorageFn
NewLRU creates a new LRU Storage. Expirations are not supported. Argument `o` can be nil, if so default values get applied.
type Service ¶
type Service struct {
// contains filtered or unexported fields
}
Service handles the encoding, decoding and caching.
func NewService ¶
func NewService(level1, level2 NewStorageFn, so *ServiceOptions) (_ *Service, err error)
NewService creates a new cache service. Arguments level1 and level2 define the cache level. For example level1 should be an LRU or another in-memory cache while level2 should be accessed via network. Only level2 is requred while level1 can be nil.
func (*Service) Get ¶
Get looks up the key and parses the raw data into the destination pointer `dst`. If `dst` implements interface
type unmarshaler interface { Unmarshal([]byte) error }
the Unmarshal gets called (or one of the interface from package `encoding`). This type check has precedence before the decoder. You have to check yourself if the returned error is of type NotFound or of any other source. Every caching type defines its own NotFound error. If dst has no pointer property, no error gets returned, instead the passed value stays empty.
func (*Service) GetMulti ¶
GetMulti allows a cache backend to retrieve several values at once. Same decoding logic applies as when calling `Get`.
func (*Service) Set ¶
func (tr *Service) Set(ctx context.Context, key string, src interface{}, expires time.Duration) error
Set puts the item in the cache. `src` gets either encoded using the previously applied encoder OR `src` gets checked if it implements interface
type marshaler interface { Marshal() ([]byte, error) }
and calls `Marshal`. (also checks for the interfaces in package "encoding"). Checking for marshaler has precedence. Useful with protobuf.
type ServiceOptions ¶
type ServiceOptions struct { // Codec optionally encodes and decodes an object. The default "codec" // checks if a type implements Marshal() or Unmarshal() interface or any of // the two interfaces from package "encoding". Codec Codecer // PrimeObjects creates new encoder/decoder with a sync.Pool to reuse the // objects. Setting PrimeObjects causes the encoder/decode to prime the data // which means that no type information will be stored in the cache. If you // use gob you must use still gob.Register() your types. TL;DR: Skips type // information in the cache. PrimeObjects []interface{} DefaultExpires time.Duration }
ServiceOptions used when creating a NewService.
type Storager ¶
type Storager interface { Set(ctx context.Context, keys []string, values [][]byte, expirations []time.Duration) (err error) // Get returns the bytes for given keys. The values slice must have the same // length as the keys slice. If one of the keys can't be found, its byte // slice must be `nil`. Get(ctx context.Context, keys []string) (values [][]byte, err error) Delete(ctx context.Context, keys []string) (err error) Truncate(ctx context.Context) (err error) Close() error }
Storager defines a custom backend cache type to be used as underlying storage of the Service. Must be safe for concurrent usage. Caches which implement this interface can be enabled via build tag. The context depends if it is supported by a backend cache implementation. All keys and values have the same length. `expirations` is a list seconds with the same length as keys & values. A second entry defines when a key expires. If the entry is empty, the key does not expire.
func NewCacheSimpleInmemory ¶
NewCacheSimpleInmemory creates an in-memory map map[string]string as cache backend which supports expiration.