在Go语言项目开发中,本地缓存是优化性能的重要手段,GoCache作为轻量级的本地缓存库,能够快速帮助开发者实现内存缓存功能,无需依赖外部中间件,适合中小型项目的缓存需求。

环境准备
搭建GoCache本地缓存环境前,需要确保本地已经安装Go语言环境,建议Go版本在1.13及以上,因为后续会使用go mod管理依赖。首先创建一个空的Go项目目录,执行以下命令初始化项目:
// 初始化go mod项目,模块名可以自定义 go mod init local_cache_demo
安装GoCache依赖
GoCache是开源的第三方库,需要通过go get命令安装到项目中,执行以下命令即可完成安装:
// 安装GoCache最新版本依赖 go get github.com/patrickmn/go-cache
安装完成后,项目的go.mod文件中会自动添加对应的依赖记录,无需手动修改。
基础缓存服务实现
接下来编写代码实现基础的缓存设置、获取功能,首先创建main.go文件,引入对应的包:
package main
import (
"fmt"
"time"
// 引入GoCache库
"github.com/patrickmn/go-cache"
)
func main() {
// 创建缓存实例,默认过期时间5分钟,每10分钟清理一次过期缓存
c := cache.New(5*time.Minute, 10*time.Minute)
// 设置缓存,键为user_1,值为用户数据,过期时间使用默认的5分钟
c.Set("user_1", "张三,18,男", cache.DefaultExpiration)
// 获取缓存
value, found := c.Get("user_1")
if found {
fmt.Printf("获取到缓存数据:%vn", value)
} else {
fmt.Println("未找到对应缓存")
}
}
运行上述代码,即可看到控制台输出缓存的用户数据,说明基础的缓存设置和获取功能已经生效。
常用缓存操作
设置自定义过期时间
如果需要给某个缓存键设置单独的过期时间,可以在Set方法中传入对应的时间参数:
// 设置键为order_1的缓存,过期时间为10秒
c.Set("order_1", "订单编号1001,待支付", 10*time.Second)
删除缓存
当缓存数据失效或者需要主动清理时,可以使用Delete方法删除指定键的缓存:
// 删除键为user_1的缓存
c.Delete("user_1")
// 再次获取该键,会返回未找到
val, ok := c.Get("user_1")
fmt.Printf("删除后获取结果:%v, 是否存在:%vn", val, ok)
清空所有缓存
如果需要清空缓存实例中的所有数据,可以调用Flush方法:
// 清空所有缓存
c.Flush()
fmt.Println("清空所有缓存完成")
缓存服务封装建议
在实际项目中,建议将缓存操作封装成独立的工具类,避免重复代码,同时方便后续扩展。以下是一个简单的封装示例:
package cache_util
import (
"time"
"github.com/patrickmn/go-cache"
)
// 缓存工具结构体
type LocalCache struct {
cache *cache.Cache
}
// 初始化缓存工具
func NewLocalCache(defaultExp time.Duration, cleanupInterval time.Duration) *LocalCache {
return &LocalCache{
cache: cache.New(defaultExp, cleanupInterval),
}
}
// 设置缓存
func (l *LocalCache) Set(key string, value interface{}, exp time.Duration) {
l.cache.Set(key, value, exp)
}
// 获取缓存
func (l *LocalCache) Get(key string) (interface{}, bool) {
return l.cache.Get(key)
}
// 删除缓存
func (l *LocalCache) Delete(key string) {
l.cache.Delete(key)
}
封装后可以在项目其他模块直接引入使用,提升代码的可维护性。