|
|
|
#### 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` |
|
|
|
|
| -cache_err |continue| 缓存出错的时候的行为 continue: 继续执行 break: 抛出错误 方法返回|break|
|
|
|
|
| -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 |
|
|
|
|
| -struct_name | dao | 所属结构体名称 | Dao|
|