mirror of
https://github.com/go-kratos/kratos.git
synced 2025-01-22 03:38:41 +02:00
genbts
缓存代码生成
项目简介
从缓存中获取数据 如果miss则调用回源函数从数据源获取 然后塞入缓存
支持以下功能:
- 单飞限制回源并发 防止打爆数据源
- 空缓存 防止缓存穿透
- 分批获取数据 降低延时
- 默认异步加缓存 可选同步加缓存
- prometheus回源比监控
- 多行注释生成代码
- 支持分页(限单key模板)
- 自定义注释
- 支持忽略参数
使用方式:
- 在dao package中 增加注解 //go:generate kratos tool genbts 定义bts接口 声明需要的方法
- 在dao 文件夹中执行 go generate命令 将会生成相应的缓存代码
- 调用生成的XXX方法
- 示例见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 |