基本介绍

缓存组件同时提供了gcacheRedis缓存适配实现。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
}

注意事项

关于Clear/Size等方法

首先,相同的gredis.Config总是会连接到相同的redis db中,而由于Redis本身没有数据分组功能,所以当多个gcache.Cache对象连接到同个redis db时,将会共享整个redis db,而不会单独开辟一个分组用来存储当前gcache.Cache对象中的内容。因此当使用ClearSize这类操作时,将会对整个redis db进行操作,而不是与内存缓存一样的仅操作当前gcache.Cache对象中的内容,存在一定的反直觉,请务必谨慎使用。

建议使用不同的redis db区分业务缓存类型

另外,建议大家在使用Redis缓存时,单独配置不同的db来使用,而不是和其他的业务数据共用一个db