gcache提供统一的缓存管理模块,提供了开发者可自定义灵活接入的缓存适配接口,并默认提供了高速内存缓存适配实现。

先说结论

这篇文章通过结合商业项目的使用场景,为大家介绍了gcache的基本使用、缓存控制以及淘汰策略。

使用gcache做缓存处理,简单方便易上手!

优势

gcacheCPUns

基本使用

gcache.New()

也可以直接使用gcache包方法,使用方式都是一样的。

下面代码段介绍了gcache的基本使用:

打印结果

缓存控制

下面介绍一些特殊场景的用法:

SetIfNotExist
GetOrSet

打印结果

缓存淘汰策略

之前做项目的时候也有这么设计过,现在gcache天然支持缓存淘汰策略

实战举例

给大家举个项目中的栗子:

比如我有一个新闻网站,为了保证新闻详情页的加载速度,会把新闻详情页做缓存处理(内容缓存,评论点赞等动态获取。)

一般来说新产生的新闻热度和访问量会更高,需要做缓存,而陈旧的新闻因为热度不再,访问量较低就从缓存中释放了。

解决上面的问题一般有2种思路:

  • 设置缓存时间是一个解决思路
  • 另外的思路就是设置缓存的淘汰策略。

比如:我一共允许缓存1万个缓存详情页,当超过1万个时,会淘汰掉最早缓存的数据,实现动态且稳定的缓存策略。

gcache天然支持这种缓存淘汰策略

代码示例

下面举个简单的栗子:

打印结果

小技巧

GetOrSetFunc的使用

GetOrSetFuncf func() (interface{}, error)f

总结

这篇文章通过结合商业项目的使用场景,为大家介绍了gcache的基本使用、缓存控制以及淘汰策略。

单机项目可以使用gcache做缓存处理,简单方便易上手;