之前写过一篇重复请求怎么办? 地址:https://www.yunask.cn/post/109e4ed7.html
使用AOP
加Redis
的方式实现分布式锁,写完没多久,就看到好几篇差不多的,而且我关注的一个公众号还推给我,看到觉得有点尴尬,不过这个也没什么,毕竟写出来就是给人看的。
其实代码不难,主要是思路,我们习惯了在代码里这样写:
- 一进到接口里,先查一下Redis里有没有指定
key
的数据 - 如果有那就直接返回提示信息,没有的话,就在
Redis
放个数据,然后执行具体的业务操作 - 执行完毕,删除Redis中这个
key
的数据。
可是这很明显是重复劳动啊,我这么懒的人容忍不了。
后来也就有了使用AOP
加Redis
的方式实现的分布式锁。
开始
今天再来探讨一下缓存,同样的原理。一般添加缓存的方式是:
- 先用生成的唯一
key
查询缓存,缓存有,直接从缓存中取出,然后返回 - 缓存中没有,查询数据库,放到缓存中,然后把查到的数据返回
动手
还是使用拦截注解的方式。定义一个注解Cache
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
public @interface Cache {
/**
* @return 缓存时间,默认1分钟
*/
int value() default 1;
/**
* @return 时间单位
*/
TimeUnit unit() default TimeUnit.MINUTES;
/**
* @return true 在日志中使用hashcode来记录,否则使用字符串的方式,主要是为了安全
*/
boolean hash() default true;
}
<