1
0
mirror of https://github.com/go-kratos/kratos.git synced 2025-01-24 03:46:37 +02:00
kratos/tool/kratos-gen-bts
2019-05-20 18:25:47 +08:00
..
2019-05-20 18:25:47 +08:00
2019-05-14 13:57:02 +08:00
2019-05-14 13:57:02 +08:00
2019-05-20 18:19:47 +08:00
2019-05-14 13:57:02 +08:00
2019-05-14 14:11:09 +08:00
2019-05-14 13:57:02 +08:00

genbts

缓存代码生成

项目简介

从缓存中获取数据 如果miss则调用回源函数从数据源获取 然后塞入缓存

支持以下功能:

  • 单飞限制回源并发 防止打爆数据源
  • 空缓存 防止缓存穿透
  • 分批获取数据 降低延时
  • 默认异步加缓存 可选同步加缓存
  • prometheus回源比监控
  • 多行注释生成代码
  • 支持分页(限单key模板)
  • 自定义注释
  • 支持忽略参数
使用方式:
  1. 在dao package中 增加注解 //go:generate kratos tool genbts 定义bts接口 声明需要的方法
  2. 在dao 文件夹中执行 go generate命令 将会生成相应的缓存代码
  3. 调用生成的XXX方法
  4. 示例见testdata/dao.go

要求: dao里面需要有cache对象 代码会调用d.cache来新增缓存 需要实现代码中所需的方法 每一个缓存方法都需要实现以下方法: 从缓存中获取数据 名称为Cache+方法名 函数定义和声明一致 从数据源(db/api/...)获取数据 名称为Raw+方法 函数定义和声明一致 存入缓存方法 名称为AddCache+方法名 函数定义为 func AddCache方法名(c context.Context, ...) (error)

注解参数:
参数名称 默认值 说明 示例
-nullcache 空指针对象(存正常业务不会出现的内容 id的话像是-1这样的) &Demo{ID:-1} 或-1 或"null"
-check_null_code 开启空缓存并且value为指针对象时必填 用于判断是否是空缓存 $来指代对象名 -check_null_code=$!=nil&&$.ID==-1 或 $ == -1
-batch (限多key模板) 批量获取数据 每组大小 100
-max_group (限多key模板)批量获取数据 最大组数量 10
-batch_err break (限多key模板)批量获取数据回源错误的时候 降级继续请求(continue)还是直接返回(break) break 或 continue
-singleflight false 是否开启单飞(开启后生成函数会多一个单飞名称参数 生成的代码会调用d.cacheSFNAME方法获取单飞的key) true
-sync false 是否同步增加缓存 false
-paging false (限单key模板)分页 数据源应返回2个值 第一个为对外数据 第二个为全量数据 用于新增缓存 false
-ignores 用于依赖的三个方法参数和主方法参数不一致的情况. 忽略方法的某些参数 用|分隔方法逗号分隔参数 pn,ps|pn|origin 表示"缓存获取"方法忽略pn,ps两个参数 回源方法忽略pn参数 加缓存方法忽略origin参数
-custom_method false 自定义方法名 |分隔 缓存获取方法名|回源方法名|增加缓存方法名 d.mc.AddDemo|d.mysql.Demo|d.mc.AddDemo