springboot 使用 @cacheable 可以方便的管理缓存数据,在不指定 key 属性的情况下,默认使用 simplekeygenerator 生成 key。除此之外,我们也可以自定义实现 keygenerator 接口,生法治基本含义的主要内容是什么成自己的 key 名称策略。
mysimplekey类的作用是存放参数数据,必须实现equals、hashcode。如果需要自定义key格式,同样需要实现tostring接口,下面的例子是把参数用逗号分隔。
public class mysimplekey implements rializable { public static final mysimplekey empty = new mysimplekey(new object[0]); private final object[] params; private transient int hashcode; public mysimplekey(object... elements) { asrt.notnull(elements, "elements must not be null"); this.params = (object[])elements.clone(); this.hashcode = arrays.deephashcode(this.params); } public boolean equals(@nullable object other) { return this == other || other instanceof mysimplekey && arrays.deepequals(this.params, ((mysimplekey)other).params); } public final int hashcode(北京舞蹈学院分数线) { return this.hashcode; } public string tostring() { return stringutils.arraytocommadelimitedstring(this.params); }}
mykeygenerator 实现 keygenerator 的接口,里面只有一个 generate 方法
public class mykeygenerator implements keygenerator { @override public object generate(object o, method method, object... objects) { if (objects.length == 0) { return mysimplekey.empty; } el { if (objects.length == 1) { object param = objects[0]; if (param != null && !param.getclass().isarray()) { return param; } } return new mysimplekey(objects); } }}
定义mykeygenerator bean:
@componentpublic class myredisconf { @bean public mykeygenerator mykeygenerator(){ return new mykeygenerator(); }}
在 @cacheable 配置 keygenerator 属性,值就是前面配置的bean名称
@override @cacheable(value = {"redis:getstring3"}, keygenerator = "mykeygenerator") public string getstring3(string tag, string name) { return tag + " " + name; }
测试结果如下,tag、name 参数确实以逗号分隔
127.0.0.1:6379[5]> keys *
1) “redis:getstring3::hello,zhangsan”
为了便于key的不重复,我们可以手动设置key有类名、方法名、参数等组合
属性名称描述
示例
methodname
当前方法名
#root.methodname
method
当前方法
#root.method.name
target
当前被调用的对象
#root.target
targetclass
当前被调用的对象的class
#root.targetclass
args
当前方法参数组成的数组
#root.args[0]
caches
当前被调用的方法使用的cache
#root.caches[0].name
key = "#root.targetclass.simplename+':'+#root.methodname+':'+#param"
如下图所示
1、自定义cachekeygenerator 实现keygenerator
public class cachekeygenerator implements keygenerator { /** * (非 javadoc) * <p> * title: generate * </p> * * @param target * @param method * @param params * @return * @e org.springframework.cache.interceptor.keygenerator#generate(java.lang.object, * java.lang.reflect.method, java.lang.object[]) */ @override public object generate(object target, method method, object... params) { stringbuilder key = new stringbuilder(); key.append(target.getclass().getsimplename()).append(":").append(method.getname()).append(":"); if (params.length == 0) { return key.tostring(); } for (int i = 0; i < params.length; i++) { object param = params[i]; if (param == null || param instanceof logableparam) { del(key); } el if (classutils.isprimitivearray(param.getclass())) { int length = array.getlength(param); for (int j = 0; j < length; j++) { key.append(array.get(param, j)); key.append(','); } } el if (classutils.isprimitiveorwrapper(param.getclass()) || param instanceof string) { key.append(param); } el { key.append(param.tostring()); } key.append('-'); } del(key); return key.tostring(); } private stringbuilder del(stringbuilder stringbuilder) { if (stringbuilder.tostring().endswith("-")) { stringbuilder.deletecharat(striln求导ngbuilder.length() - 1); 水侵 } return stringbuilder; }}
2、配置xml
<cache:annotation-driven cache-manager="cachemanager" key-generator="cachekeygenerator" proxy-target-class="true" /><bean id="cachekeygenerator" class="com.tensoon.util.cachekeygenerator"></bean>
3、配置注解
如下图所示
以上为个人经验,希望能给大家一个参考,也希望大家多多支持www.887551.com。
本文发布于:2023-04-04 05:09:35,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/b045bf6f94876f29d93d52e7e38a2305.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:SpringBoot @Cacheable自定义KeyGenerator方式.doc
本文 PDF 下载地址:SpringBoot @Cacheable自定义KeyGenerator方式.pdf
留言与评论(共有 0 条评论) |