command
Version:
v0.0.0-...-8dc72f4
Opens a new window with list of versions in this module.
Published: Jun 20, 2019
License: MIT
Opens a new window with license information.
Imports: 13
Opens a new window with list of imports.
Imported by: 0
Opens a new window with list of known importers.
README
¶
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 |
Documentation
¶
There is no documentation for this package.
Source Files
¶
Click to show internal directories.
Click to hide internal directories.