You are viewing an old version of this page. View the current version.
Compare with Current View Page History
« Previous Version 12 Current »
缓存组件同时提供了gcache的Redis缓存适配实现。Redis缓存在多节点保证缓存的数据一致性时非常有用,特别是Session共享、数据库查询缓存等场景中。
gcache
Redis
Session
func ExampleCache_SetAdapter() { var ( err error ctx = gctx.New() cache = gcache.New() redisConfig = &gredis.Config{ Address: "127.0.0.1:6379", Db: 9, } cacheKey = `key` cacheValue = `value` ) // Create redis client object. redis, err := gredis.New(redisConfig) if err != nil { panic(err) } // Create redis cache adapter and set it to cache object. cache.SetAdapter(gcache.NewAdapterRedis(redis)) // Set and Get using cache object. err = cache.Set(ctx, cacheKey, cacheValue, time.Second) if err != nil { panic(err) } fmt.Println(cache.MustGet(ctx, cacheKey).String()) // Get using redis client. fmt.Println(redis.MustDo(ctx, "GET", cacheKey).String()) // Output: // value // value }
首先,相同的gredis.Config总是会连接到相同的redis db中,而由于Redis本身没有数据分组功能,所以当多个gcache.Cache对象连接到同个redis db时,将会共享整个redis db,而不会单独开辟一个分组用来存储当前gcache.Cache对象中的内容。因此当使用Clear、Size这类操作时,将会对整个redis db进行操作,而不是与内存缓存一样的仅操作当前gcache.Cache对象中的内容,存在一定的反直觉,请务必谨慎使用。
gredis.Config
redis db
gcache.Cache
Clear
Size
另外,建议大家在使用Redis缓存时,单独配置一个db来使用,而不是和其他的业务数据共用一个db。
db