golang 基于mysql到内存map的缓存库

golang 基于mysql到内存map的缓存库

背景

  • 很多业务上需要读取db里面的数据详情,这些数据已经存在db,会修改但不会删除,程序为了加速访问需要缓存到内存,业务上也允许内存和db 不一致,设计一个通用的dbcache 由此而来

最佳实践

cache := NewCache(24*time.Hour, 10*time.Minute, 10, 10, "root:test@tcp(127.0.0.1:3306)/test?parseTime=True&loc=Local&multiStatements=true&charset=utf8")
    c := Cri{}
    cache.RegisterType("cri", &c)
    data, err := cache.Get("1", "cri")
    fmt.Println(data, err, "=======================")
  • . 首先new 一个cache
  • . 需要实现 Model 接口

SqlTemplate() string 返回查询sql 语句模板
UnmarshalField() Model 对象里面有些字段可能不是db直接查出而是序列号而来

  • . 注册model

func (c *Cache) RegisterType(typeName string, m Model) typeName 为类型名称,m 为实现的model(传指针)

  • . 获取值

func (c *Cache) Get(k string,typeName) (Model, error) typeName 为类型名称 k 为参数

注意

  1. 此cache 返回data为只读,不可修改
  2. mysql 需存在此model 否则会每次穿透db

git 地址 https://github.com/Bulesxz/gocommon/tree/master/dbcache