求求你不要手写redis 缓存set,get

点击上方蓝色字体,选择“标星公众号”

优质文章,第一时间送达

关注公众号后台回复paymall获取实战项目资料+视频

作者:小李子说程序

https://www.toutiao.com/i6903746076747104772/

前言

看到同事手动写的缓存代码,我实在是看不下去了,于是决定改造一下,最终达到自动Redis缓存,不用手动去set了。

使用场景

实时性要求不那么高的业务数据,我们可以在Service上进行一些缓存的操作。这样就可以减少访问数据库的频率。(脱离的场景的技术都是在纸上谈兵)

实战

1 话不多说,上代码自动化配置

源码

import java.time.Duration;

import org.springframework.cache.CacheManager;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.cache.RedisCacheConfiguration;
import org.springframework.data.redis.cache.RedisCacheManager;
import org.springframework.data.redis.cache.RedisCacheWriter;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializationContext;
import org.springframework.data.redis.serializer.RedisSerializer;
@Configuration
public class RedisConfig {
 /**
  * SpringBoot配置redis作为默认缓存工具
  * SpringBoot 2.0 以上版本的配置
  */
 @Bean
    public CacheManager cacheManager(RedisConnectionFactory redisConnectionFactory) {
        //初始化一个RedisCacheWriter
        RedisCacheWriter redisCacheWriter = RedisCacheWriter.nonLockingRedisCacheWriter(redisConnectionFactory);
        //设置CacheManager的值序列化方式为json序列化
        RedisSerializer<Object> jsonSerializer = new GenericJackson2JsonRedisSerializer();
        RedisSerializationContext.SerializationPair<Object> pair = RedisSerializationContext.SerializationPair
                                                    .fromSerializer(jsonSerializer);
        RedisCacheConfiguration defaultCacheConfig=RedisCacheConfiguration.defaultCacheConfig()
                                                    .serializeValuesWith(pair)
                                                    //设置默认超过期时间是30秒
                                                    .entryTtl(Duration.ofSeconds(30));
      
        //初始化RedisCacheManager
        return new RedisCacheManager(redisCacheWriter, defaultCacheConfig);
    }
}

2 启用缓存注解

3 使用注解,实现curd

3.1 查询 使用 @Cacheable
3.2 增加或修改使用 @CachePut
3.3 删除用 @CacheEvict

有热门推荐????

肝了一晚上搞出来一个微信订阅号鉴黄机器人

数数FastJson那些年犯下的'血案'...

为什么祖传代码会被称为屎山

面试官:MyBatis的SQL执行流程说这么详细,网上抄的吧!

如何手动获取 Spring 容器中的 Bean?

史上最轻量!阿里强推的新型单元测试工具

腾讯 JDK 正式开源,高性能、太牛逼啦!

万字图解Linux网络包接收过程

点击阅读原文,前往学习SpringCloud实战项目

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值