golang 本地缓存

本文介绍了在Golang中实现本地缓存的方法,重点关注核心结构体的设计、加载策略以及遇到的问题和优化点。使用goroutine进行定时数据刷新,并强调了必须在DB连接建立后进行数据加载以及正确选择时间间隔的重要性。
摘要由CSDN通过智能技术生成

本地缓存

针对使用非常频繁的表,如某些配置表,往往查询非常频繁并且是表非常小。这个时候可以采取缓存到内存中,定时的去reload 数据,刷新缓存。

核心结构体

type LoadDataFunc func(ctx context.Context, c *cache.Cache) (map[string]interface{}, error)


type LocalCache struct {
	*cache.Cache
	name                    string // cache name
	lastUpdateTime          int64
	ctx                     context.Context
	ReloadIncrementInterval time.Duration // wait for reload data
	loadFunc                LoadDataFunc // how to load, load what
	sync.Mutex
	//flush bool
}

使用中还是主要依托于

	"github.com/patrickmn/go-cache"

已经帮忙实现个很大一部分功能,没有必要重复造轮子。
关键实现就在于

  • 如何检测时间到达然后调用reload 方法去重新load 数据。这个reload的时间间隔和load数据的时间都是应该客户应该注意的点。
  • reload 方法的时间,返回全量数据,转为cache 的格式。

实现

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值