Golang Web缓存核心是减少重复计算和数据库查询,优先用HTTP缓存头(Cache-Control、ETag)和内存/Redis缓存层;中小流量用go-cache(支持TTL),多实例用Redis(防穿透、雪崩),缓存策略须匹配数据更新频率与访问量。
用 Golang 实现 Web 应用缓存,核心是减少重复计算和数据库查询,把高频、低变动的数据暂存在内存或外部存储中。最常用且见效快的方式是结合 HTTP 缓存头 和 内存/Redis 缓存层,而不是一上来就堆复杂方案。
Go 标准库的 net/http 支持直接设置 Cache-Control、ETag、Last-Modified 等头部,让客户
端或 CDN 自动缓存静态资源或稳定接口:
w.Header().Set("Cache-Control", "public, max-age=3600")
If-None-Match 时比对,相同则返回 304private, max-age=60)适合中小流量、数据量不大、重启可丢的场景(比如用户权限树、地区列表):
sync.Map 是线程安全的,适合读多写少的键值缓存,但不支持自动过期,需自己定时清理或写 wrappergithub.com/patrickmn/go-cache:支持 TTL、自动驱逐、可选清理 goroutine,初始化简单:c := cache.New(5*time.Minute, 10*time.Minute)
"user:profile:" + userID,避免命名冲突当服务部署多个实例,或需要持久化、大容量、复杂数据结构(如排行榜、会话)时,Redis 是首选:
github.com/go-redis/redis/v9 客户端,连接池配置好 MinIdleConns 和 MaxConnAge
DEL user:profile:123,而非更新缓存值(易不一致)别为了缓存而缓存。几个关键判断点:
不复杂但容易忽略:上线前用 curl -I 检查响应头,用 redis-cli monitor 观察缓存读写,再压测对比 P95 延迟变化。