Documentation ¶
Index ¶
- Variables
- func Adapters() []string
- func CacheItemPoolRelease(item *Item)
- func Config() *ini.File
- func Decr(val interface{}) (interface{}, error)
- func HasAdapter(name string) bool
- func Incr(val interface{}) (interface{}, error)
- func Register(name string, adapter Cache)
- func Version() string
- type Cache
- type Codec
- type Doer
- type FileCacher
- func (c *FileCacher) Client() interface{}
- func (c *FileCacher) Close() error
- func (c *FileCacher) Codec() encoding.Codec
- func (c *FileCacher) Decr(ctx context.Context, key string) error
- func (c *FileCacher) Delete(ctx context.Context, key string) error
- func (c *FileCacher) Flush(ctx context.Context) error
- func (c *FileCacher) Get(ctx context.Context, key string, value interface{}) error
- func (c *FileCacher) Incr(ctx context.Context, key string) error
- func (c *FileCacher) IsExist(ctx context.Context, key string) (bool, error)
- func (c *FileCacher) Name() string
- func (c *FileCacher) Put(ctx context.Context, key string, val interface{}, expire int64) error
- func (c *FileCacher) SetCodec(codec encoding.Codec)
- func (c *FileCacher) StartAndGC(ctx context.Context, opt Options) error
- type GetAs
- func (g *GetAs) Any(ctx context.Context, key string) interface{}
- func (g *GetAs) Bytes(ctx context.Context, key string) []byte
- func (g *GetAs) Do(key string, fn func() (interface{}, error)) (v interface{}, err error, shared bool)
- func (g *GetAs) Float32(ctx context.Context, key string) float32
- func (g *GetAs) Float64(ctx context.Context, key string) float64
- func (g *GetAs) Int(ctx context.Context, key string) int
- func (g *GetAs) Int32(ctx context.Context, key string) int32
- func (g *GetAs) Int64(ctx context.Context, key string) int64
- func (g *GetAs) Map(ctx context.Context, key string) map[string]interface{}
- func (g *GetAs) Mapx(ctx context.Context, key string) param.Store
- func (g *GetAs) Slice(ctx context.Context, key string) []interface{}
- func (g *GetAs) String(ctx context.Context, key string) string
- func (g *GetAs) Uint(ctx context.Context, key string) uint
- func (g *GetAs) Uint32(ctx context.Context, key string) uint32
- func (g *GetAs) Uint64(ctx context.Context, key string) uint64
- type Getter
- type Item
- type MemoryCacher
- func (c *MemoryCacher) Client() interface{}
- func (c *MemoryCacher) Close() error
- func (c *MemoryCacher) Codec() encoding.Codec
- func (c *MemoryCacher) Decr(ctx context.Context, key string) (err error)
- func (c *MemoryCacher) Delete(ctx context.Context, key string) error
- func (c *MemoryCacher) Flush(ctx context.Context) error
- func (c *MemoryCacher) Get(ctx context.Context, key string, value interface{}) error
- func (c *MemoryCacher) Incr(ctx context.Context, key string) (err error)
- func (c *MemoryCacher) IsExist(ctx context.Context, key string) (bool, error)
- func (c *MemoryCacher) Name() string
- func (c *MemoryCacher) Put(ctx context.Context, key string, val interface{}, expire int64) error
- func (c *MemoryCacher) SetCodec(codec encoding.Codec)
- func (c *MemoryCacher) StartAndGC(ctx context.Context, opt Options) error
- type MemoryItem
- type Options
Constants ¶
This section is empty.
Variables ¶
var ( ErrNotFound = errors.New("not found") ErrExpired = errors.New("expired") ErrNotSupported = errors.New("not supported operation") )
var DefaultCodec encoding.Codec = json.JSON
Functions ¶
func CacheItemPoolRelease ¶ added in v0.3.5
func CacheItemPoolRelease(item *Item)
func HasAdapter ¶
Types ¶
type Cache ¶
type Cache interface { Name() string // Put puts value into cache with key and expire time. Put(ctx context.Context, key string, val interface{}, timeout int64) error // Get gets cached value by given key. Get(ctx context.Context, key string, value interface{}) error // Delete deletes cached value by given key. Delete(ctx context.Context, key string) error // Incr increases cached int-type value by given key as a counter. Incr(ctx context.Context, key string) error // Decr decreases cached int-type value by given key as a counter. Decr(ctx context.Context, key string) error // IsExist returns true if cached value exists. IsExist(ctx context.Context, key string) (bool, error) // Flush deletes all cached data. Flush(ctx context.Context) error // StartAndGC starts GC routine based on config string settings. StartAndGC(ctx context.Context, opt Options) error Close() error Client() interface{} Codec Getter Doer }
Cache is the interface that operates the cache data.
func Cacher ¶
Cacher is a middleware that maps a cache.Cache service into the Macaron handler chain. An single variadic cache.Options struct can be optionally provided to configure.
func NewCacher ¶
NewCacher creates and returns a new cacher by given adapter name and configuration. It panics when given adapter isn't registered and starts GC automatically.
func NewMemoryCacher ¶
func NewMemoryCacher() Cache
NewMemoryCacher creates and returns a new memory cacher.
type FileCacher ¶
type FileCacher struct { GetAs // contains filtered or unexported fields }
FileCacher represents a file cache adapter implementation.
func NewFileCacher ¶
func NewFileCacher() *FileCacher
NewFileCacher creates and returns a new file cacher.
func (*FileCacher) Client ¶
func (c *FileCacher) Client() interface{}
func (*FileCacher) Close ¶
func (c *FileCacher) Close() error
func (*FileCacher) Codec ¶
func (c *FileCacher) Codec() encoding.Codec
func (*FileCacher) Decr ¶
func (c *FileCacher) Decr(ctx context.Context, key string) error
Decr cached int value.
func (*FileCacher) Delete ¶
func (c *FileCacher) Delete(ctx context.Context, key string) error
Delete deletes cached value by given key.
func (*FileCacher) Flush ¶
func (c *FileCacher) Flush(ctx context.Context) error
Flush deletes all cached data.
func (*FileCacher) Get ¶
func (c *FileCacher) Get(ctx context.Context, key string, value interface{}) error
Get gets cached value by given key.
func (*FileCacher) Incr ¶
func (c *FileCacher) Incr(ctx context.Context, key string) error
Incr increases cached int-type value by given key as a counter.
func (*FileCacher) Name ¶ added in v0.7.2
func (c *FileCacher) Name() string
func (*FileCacher) Put ¶
Put puts value into cache with key and expire time. If expired is 0, it will be deleted by next GC operation.
func (*FileCacher) SetCodec ¶
func (c *FileCacher) SetCodec(codec encoding.Codec)
func (*FileCacher) StartAndGC ¶
func (c *FileCacher) StartAndGC(ctx context.Context, opt Options) error
StartAndGC starts GC routine based on config string settings.
type GetAs ¶
type GetAs struct { Cache // contains filtered or unexported fields }
type Getter ¶
type Getter interface { String(ctx context.Context, key string) string Int(ctx context.Context, key string) int Uint(ctx context.Context, key string) uint Int64(ctx context.Context, key string) int64 Uint64(ctx context.Context, key string) uint64 Int32(ctx context.Context, key string) int32 Uint32(ctx context.Context, key string) uint32 Float32(ctx context.Context, key string) float32 Float64(ctx context.Context, key string) float64 Bytes(ctx context.Context, key string) []byte Map(ctx context.Context, key string) map[string]interface{} Any(ctx context.Context, key string) interface{} Mapx(ctx context.Context, key string) param.Store Slice(ctx context.Context, key string) []interface{} }
type Item ¶
Item represents a cache item.
func CacheItemPoolGet ¶ added in v0.3.5
func CacheItemPoolGet() *Item
type MemoryCacher ¶
type MemoryCacher struct { GetAs // contains filtered or unexported fields }
MemoryCacher represents a memory cache adapter implementation.
func (*MemoryCacher) Client ¶
func (c *MemoryCacher) Client() interface{}
func (*MemoryCacher) Close ¶
func (c *MemoryCacher) Close() error
func (*MemoryCacher) Codec ¶
func (c *MemoryCacher) Codec() encoding.Codec
func (*MemoryCacher) Decr ¶
func (c *MemoryCacher) Decr(ctx context.Context, key string) (err error)
Decr decreases cached int-type value by given key as a counter.
func (*MemoryCacher) Delete ¶
func (c *MemoryCacher) Delete(ctx context.Context, key string) error
Delete deletes cached value by given key.
func (*MemoryCacher) Flush ¶
func (c *MemoryCacher) Flush(ctx context.Context) error
Flush deletes all cached data.
func (*MemoryCacher) Get ¶
func (c *MemoryCacher) Get(ctx context.Context, key string, value interface{}) error
Get gets cached value by given key.
func (*MemoryCacher) Incr ¶
func (c *MemoryCacher) Incr(ctx context.Context, key string) (err error)
Incr increases cached int-type value by given key as a counter.
func (*MemoryCacher) Name ¶ added in v0.7.2
func (c *MemoryCacher) Name() string
func (*MemoryCacher) Put ¶
Put puts value into cache with key and expire time. If expired is 0, it will be deleted by next GC operation.
func (*MemoryCacher) SetCodec ¶
func (c *MemoryCacher) SetCodec(codec encoding.Codec)
func (*MemoryCacher) StartAndGC ¶
func (c *MemoryCacher) StartAndGC(ctx context.Context, opt Options) error
StartAndGC starts GC routine based on config string settings.
type MemoryItem ¶
type MemoryItem struct {
// contains filtered or unexported fields
}
MemoryItem represents a memory cache item.
type Options ¶
type Options struct { // Name of adapter. Default is "memory". Adapter string // Adapter configuration, it's corresponding to adapter. AdapterConfig string // GC interval time in seconds. Default is 60. Interval int // Occupy entire database. Default is false. OccupyMode bool // Configuration section name. Default is "cache". Section string }
Options represents a struct for specifying configuration options for the cache middleware.