SpringBoot之redis缓存的基本配置及使用

【饿了么、美团】外卖红包领取地址 >> 能省一点是一点

SpringBoot在缓存方面对多种缓存均提供了支持,以下是他支持的缓存类型:

Generic
JCache (JSR-107) (EhCache 3, Hazelcast, Infinispan, and others)
EhCache 2.x
Hazelcast
Infinispan
Couchbase
Redis
Caffeine
Simple

本文将主要介绍SpringBoot和redis的整合配置及使用。注:SpringBoot 1.x版本和SpringBoot 2.x版本在配置上存在些许不同,这里采用的2.x版本。

引入SpringBoot的缓存及redis缓存的jar包依赖

<!--cache-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-cache</artifactId>
</dependency>

<!--redis-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

在application.yml文件中配置缓存类型为redis并配置redis的地址、端口、密码等。

spring:
  cache:
    type: REDIS
  redis:
    host: localhost
    port: 6379
    password: 123456
    database: 0

启动类上增加@EnableCaching注解,没有增加这个注解的话,缓存将不会生效。

至此你已经可以在你的项目中进行redis缓存相关的操作了,但是因为SpringBoot默认使用JdkSerializationRedisSerializer作为redis缓存中value的序列化类,所以当你使用第三方工具去redis中查看value值的时候你看到的将会是一堆乱码,不利于开发调试。为了解决这个问题我们可以增加一个RedisConfig类来对redis进行自定义的配置。

@Configuration
public class RedisConfig {

    /**
     * 默认超时时间
     */
    private static final long DEFAULT_TTL = 999999L;

    @Bean
    public CacheManager cacheManager(RedisConnectionFactory redisConnectionFactory) {
        //初始化一个RedisCacheWriter
        RedisCacheWriter redisCacheWriter = RedisCacheWriter.nonLockingRedisCacheWriter(redisConnectionFactory);
        //自定义key前缀
        CacheKeyPrefix cacheKeyPrefix = new CacheKeyPrefix() {
            @Override
            public String compute(String cacheName) {
                return cacheName+":";
            }
        };
        //设置CacheManager的值序列化方式为json序列化
        RedisSerializer<Object> jsonSerializer = new GenericJackson2JsonRedisSerializer();
        RedisSerializationContext.SerializationPair<Object> pair = RedisSerializationContext.SerializationPair
                .fromSerializer(jsonSerializer);
        //生成RedisCacheConfiguration配置
        RedisCacheConfiguration defaultCacheConfig = RedisCacheConfiguration.defaultCacheConfig()
                .computePrefixWith(cacheKeyPrefix)
                .serializeValuesWith(pair);
        //设置默认过期时间
        defaultCacheConfig.entryTtl(Duration.ofSeconds(DEFAULT_TTL));
        //初始化RedisCacheManager
        return new RedisCacheManager(redisCacheWriter, defaultCacheConfig);
    }

}

新建一个RedisConfig类。类的内容如上,这里我配置了默认过期时间为999999秒,并设置redis的key为cacheName:xxx的形式,更改value值的序列化为json格式。

现在我们可以愉快的在项目中使用redis了。SpringBoot帮我们针对缓存的操作做了封装,我们可以直接使用注解来快速方便的使用redis。

常用的有如下3个注解

@Cacheable  使用缓存
@CachePut   更新缓存
@CacheEvict 清理缓存

他们的参数基本都是一样的,只是功能有所不同,这里不多展开,只拿@Cacheable进行举例讲解。他的参数及功能解释如下表:

参数 介绍 样例
value或cacheNames 缓存名,用于区分不同的模块;在redis中的区别就是key前缀会增加缓存名: @Cacheable(value="mycache")
key 缓存的key,可以为空;需要指定key可以使用SpEL表达式编写;不指定则默认按照方法的所有参数进行组合 @Cacheable(value="testcache",key="#userName") @Cacheable(value="testcache",key="#root.methodName")
condition 缓存的条件,可以为空;使用SpEL编写,返回true则缓存数据 @Cacheable(value="testcache",condition="#userName.length()>2")

为了方便获取入参中的数据,在参数key中的SpEL表达式中,SpringBoot默认提供了一个root对象。使用及解释见下表:

样例 解释
#root.methodName 当前被调用的方法名
#root.method 当前被调用的方法
#root.target 当前被调用的目标对象
#root.targetClass 当前被调用的目标对象类

虽然SpringBoot提供了非常方便的注解供我们使用,但是请注意,由于注解的实现原理是通过代理对象来实现的,所以在同一个类中自己的方法A调用带缓存注解的方法B,此时注解是不会生效的,也就是缓存不会生效。那么有时候我们实际业务确实有这种需求怎么办?我们可以直接在类中注入SpringBoot提供的模板类来对redis进行操作。

@Autowired
private RedisTemplate redisTemplate;

具体的操作非常简单易懂,网上资料也很多,这里就不过多赘述。

代码:https://gitee.com/lqccan/blog-demo/tree/master/SpringBoot/redis
测试方法见:DemoApplicationTest单元测试


觉得内容还不错?打赏个钢镚鼓励鼓励!!👍

Bloombagz 透气控根软花盆 彩色双层种植袋 广交会CF奖 大号庭院阳台花卉绿植生长袋 2加仑(果绿)
¥21.60
慧恩 儿童清清宝 菊花晶 草本配方奶伴侣 秋小泱经典盒装(5g*18袋)
¥25.90
修年堂 女贞子250g/瓶 女贞籽 冬青子泡水泡酒煲汤泡水
¥25.20
齐心(COMIX)B5 154页商务皮面笔记本子/记事本/日记本 Compera精英系列 黑色 办公文具 C8001
¥31.40
QUATREFOIL 墙纸自粘墙贴防水墙壁贴纸卧室客厅背景墙翻新贴膜纸 0.6*5米白色玫瑰
¥26.60
GIANXI 智能显温保温杯316不锈钢内胆带温度显示水杯大容量随行车载杯子茶水过滤办公泡茶杯 黑色500ml
¥28.80
临犀书法字帖经典文化系列 诗经精选 硬笔楷书临摹字帖进阶练习版 大学生成年人回米格钢笔练字帖
¥16.73
居家防滑拖鞋浴室凉拖鞋男女塑料情侣凉拖鞋静音拖鞋 男款灰 40-41码
¥16.90