用于防止缓存击穿的自动更新缓存注解-StrongCacheUtil

用于防止缓存击穿的自动更新缓存注解-StrongCacheUtil

  • 介绍
  • 使用
    • 1.添加依赖
    • 2.开启aop
    • 3.配置redis
    • 4.添加工具类
    • 5.方法上添加注解
  • 注解中各参数
  • 实现原理

介绍

用于防止缓存击穿的自动更新缓存注解,打上注解的方法只需要在其中实现查库逻辑返回数据即可,配合Spring官方的cache注解的@CacheEvict()达到保证缓存一致性的同时更新缓存(非强一致性)。demo和工具类:https://github.com/ZGOD9527/StrongCacheUtil

使用

添加依赖-开启aop-配置redis-添加工具类-使用注解

1.添加依赖

		<dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <!-- redis -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>
        <!-- aop -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-aop</artifactId>
        </dependency>
        <!-- redisson 分布式锁 https://mvnrepository.com/artifact/org.redisson/redisson -->
        <dependency>
            <groupId>org.redisson</groupId>
            <artifactId>redisson</artifactId>
            <version>3.13.4</version>
        </dependency>
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-pool2</artifactId>
            <version>2.6.1</version>
        </dependency>

2.开启aop

在@SpringBootApplication修饰的类上添加如下注解

@EnableAspectJAutoProxy

3.配置redis

#redis
spring.redis.host = localhost
spring.redis.port = 6379
spring.redis.database = 2
spring.redis.password =
spring.redis.timeout = 120000
spring.redis.lettuce.pool.max-active = 32
spring.redis.lettuce.pool.min-idle = 1
spring.redis.lettuce.pool.max-idle = 8
spring.redis.lettuce.pool.max-wait = -1

4.添加工具类

1)如果项目中没有配置缓存和redisson分布式锁配置,则将CacheConfig和RedissonConfig放到项目中
2)将CacheUtil放到项目中,修改好包路径
3)如果想使用其他分布式锁比如zookeeper,可以粘贴CacheUtil2和util/lock包下的相关文件

5.方法上添加注解

在需要获取数据并缓存的方法上添加@CacheUtil-Cacheable()注解

	@CacheUtil.Cacheable("strongCache-get1")
    @Override
    public Object get1(int var1) {
        System.out.println("get1:未走缓存");
        return var1;
    }
    @CacheUtil.Cacheable(value = "strongCache-get2", key = "#var1 +'_'+ #var2")
    @Override
    public Object get2(int var1, int var2) {
        System.out.println("get2:未走缓存");
        return var1 + "_" + var2;
    }

注解中各参数

参数 解释
vale 缓存区域,类似在redis创建了一个文件夹,默认取类名加方法名
cacheNames 缓存区域同value
key 缓存区域下的键,一般由方法形参的值组成,默认生成方式参照SimpleKeyGenerator
lockKey 分布式锁的名,默认跟value,key相关
expire 锁失效时间,毫秒值,默认5000
sleepMillis 拿锁失败后睡眠时间,毫秒值,默认90-120随机数

实现原理

用于防止缓存击穿的自动更新缓存注解-StrongCacheUtil_第1张图片
链接: github/StrongCacheUtil.

你可能感兴趣的:(java)