mirror of
https://github.com/astaxie/beego.git
synced 2025-01-10 12:37:12 +00:00
60 lines
1.0 KiB
Markdown
60 lines
1.0 KiB
Markdown
|
## cache
|
||
|
cache is a Go cache manager. It can use many cache adapters. The repo is inspired by `database/sql` .
|
||
|
|
||
|
|
||
|
## How to install?
|
||
|
|
||
|
go get github.com/astaxie/beego/cache
|
||
|
|
||
|
|
||
|
## What adapters are supported?
|
||
|
|
||
|
As of now this cache support memory, Memcache and Redis.
|
||
|
|
||
|
|
||
|
## How to use it?
|
||
|
|
||
|
First you must import it
|
||
|
|
||
|
import (
|
||
|
"github.com/astaxie/beego/cache"
|
||
|
)
|
||
|
|
||
|
Then init a Cache (example with memory adapter)
|
||
|
|
||
|
bm, err := cache.NewCache("memory", `{"interval":60}`)
|
||
|
|
||
|
Use it like this:
|
||
|
|
||
|
bm.Put("astaxie", 1, 10 * time.Second)
|
||
|
bm.Get("astaxie")
|
||
|
bm.IsExist("astaxie")
|
||
|
bm.Delete("astaxie")
|
||
|
|
||
|
|
||
|
## Memory adapter
|
||
|
|
||
|
Configure memory adapter like this:
|
||
|
|
||
|
{"interval":60}
|
||
|
|
||
|
interval means the gc time. The cache will check at each time interval, whether item has expired.
|
||
|
|
||
|
|
||
|
## Memcache adapter
|
||
|
|
||
|
Memcache adapter use the [gomemcache](http://github.com/bradfitz/gomemcache) client.
|
||
|
|
||
|
Configure like this:
|
||
|
|
||
|
{"conn":"127.0.0.1:11211"}
|
||
|
|
||
|
|
||
|
## Redis adapter
|
||
|
|
||
|
Redis adapter use the [redigo](http://github.com/gomodule/redigo) client.
|
||
|
|
||
|
Configure like this:
|
||
|
|
||
|
{"conn":":6039"}
|