返回顶部
首页 > 资讯 > 后端开发 > Python >使用SpringCache加Redis做缓存
  • 696
分享到

使用SpringCache加Redis做缓存

2024-04-02 19:04:59 696人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

目录Redis + springCache1. 添加依赖2. 使用配置类注入相关组件3. 使用以下注解4. 配置5. 存储格式6. 注意点Redis做缓存和SprinGCache缓存

Redis + SpringCache

1. 添加依赖


<!-- redis -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<!-- spring2.X集成redis所需common-pool2-->
<dependency>
    <groupId>org.apache.commons</groupId>
    <artifactId>commons-pool2</artifactId>
    <version>2.6.0</version>
</dependency>

2. 使用配置类注入相关组件


@Configuration
@EnableCaching
public class RedisConfig extends CachingConfigurerSupport {
    @Bean
    public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {
        RedisTemplate<String, Object> template = new RedisTemplate<>();
        RedisSerializer<String> redisSerializer = new StringRedisSerializer();
        Jackson2JSONRedisSerializer jackson2jsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
        ObjectMapper om = new ObjectMapper();
        om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
        jackson2JsonRedisSerializer.setObjectMapper(om);
        template.setConnectionFactory(factory);
        //key序列化方式
        template.seTKEySerializer(redisSerializer);
        //value序列化
        template.setValueSerializer(jackson2JsonRedisSerializer);
        //value HashMap序列化
        template.setHashValueSerializer(jackson2JsonRedisSerializer);
        return template;
    }
    @Bean
    public CacheManager cacheManager(RedisConnectionFactory factory) {
        RedisSerializer<String> redisSerializer = new StringRedisSerializer();
        Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
        //解决查询缓存转换异常的问题
        ObjectMapper om = new ObjectMapper();
        om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
        jackson2JsonRedisSerializer.setObjectMapper(om);
        // 配置序列化(解决乱码的问题),过期时间600秒
        RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig()
                .entryTtl(Duration.ofSeconds(600))
                .serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(redisSerializer))
                .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(jackson2JsonRedisSerializer))
                .disableCachingNullValues();
        RedisCacheManager cacheManager = RedisCacheManager.builder(factory)
                .cacheDefaults(config)
                .build();
        return cacheManager;
    }
}

3. 使用以下注解

  • @Cacheable:根据方法对返回结果进行缓存,下次请求时,如果缓存存在,则直接读取缓存数据返回,如果缓存不存在,则执行方法,并把返回结果存入缓存,一般用在查询方法上
  • @CachePut:每次都会执行方法,并将结果存入缓存,其他方法可以直接读取,一般用在新增方法上
  • @CacheEvict:会清除指定的缓存,一般用在更新或删除方法上

注解1和2的属性

注解属性 作用
value 必填,缓存名,指定命名空间
cacheNames 和value类似
key 可选,可以用spEL自定义key

注解3多出两个

注解属性 作用
allEntries 如果指定为true,方法调用将清空所有缓存
beforeInvocation 是否在方法执前清空,默认为false

4. 配置


spring.redis.host=127.0.0.1
spring.redis.port=6379
spring.redis.database= 0
spring.redis.timeout=1800000

5. 存储格式

value + "::" + key 的格式

例如:


@Cacheable(value = "space", key = "'key'")

缓存的键就是:


space::key

6. 注意点

key中如果是字符串需要加单引号,如果是spEL则不需要

Redis做缓存和SpringCache缓存

记录一下Redis做缓存和SpringCache缓存的区别

1.Redis做缓存的话,相当于是一个第三方缓存,所以项目重启之后缓存数据还是存在的

2.SpringCache作缓存的话是建立在JVM上的,所以项目启动之后缓存是自动消失的。

业务:在邮件验证码、短信验证码情况下需要设置过期时间。

如何使用:用Redis和SpringCache两种使用方法。

过期时间:如果需要设置过期时间的话,需要使用到redis。如果不需要设置过期时间,则Redis和SpringCache都可以。

SpringCache 使用方法

1.在启动类使用@EnableCaching


@SpringBootApplication
@EnableCaching //启动SpringCache缓存
public class GatheringApplication {}

2.是需要添加缓存的时候使用@Cacheable


//存入缓存
@Cacheable(value = "gathering",key = "#id")
public Gathering findById(String id){}3.在需要删除缓存的时候使用@CacheEvict
//删除
@CacheEvict(value = "gathering",key = "#gathering.id")
public void update(Gathering gathering){}

下面是SpringDataRedis的部分使用方法:



redisTemplate.opsForValue().set(REDIS_ARTICLE_KEY+"_"+id,article,10, TimeUnit.SECONDS); 
stringRedisTemplate.opsForValue().set("test", "100",60*10,TimeUnit.SECONDS);//向redis里存入数据和设置缓存时间 
stringRedisTemplate.opsForValue().get("test")//根据key获取缓存中的val
stringRedisTemplate.boundValueOps("test").increment(-1);//val做-1操作
stringRedisTemplate.boundValueOps("test").increment(1);//val +1
stringRedisTemplate.getExpire("test")//根据key获取过期时间
stringRedisTemplate.getExpire("test",TimeUnit.SECONDS)//根据key获取过期时间并换算成指定单位
stringRedisTemplate.delete("test");//根据key删除缓存
stringRedisTemplate.hasKey("546545");//检查key是否存在,返回boolean值
stringRedisTemplate.expire("red_123",1000 , TimeUnit.MILLISECONDS);//设置过期时间
stringRedisTemplate.opsForSet().add("red_123", "1","2","3");//向指定key中存放set集合
stringRedisTemplate.opsForSet().isMember("red_123", "1")//根据key查看集合中是否存在指定数据
stringRedisTemplate.opsForSet().members("red_123");//根据key获取set集合

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: 使用SpringCache加Redis做缓存

本文链接: https://lsjlt.com/news/161354.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 使用SpringCache加Redis做缓存
    目录Redis + SpringCache1. 添加依赖2. 使用配置类注入相关组件3. 使用以下注解4. 配置5. 存储格式6. 注意点Redis做缓存和SpringCache缓存...
    99+
    2024-04-02
  • Java SpringCache+Redis缓存数据详解
    目录前言一、什么是SpringCache二、项目集成Spring Cache + Redis1、配置方式三、使用Spring Cache四、SpringCache原理与不足1、读模式...
    99+
    2024-04-02
  • SpringBoot+SpringCache实现两级缓存(Redis+Caffeine)
    1. 缓存、两级缓存 1.1 内容说明 Spring cache:主要包含spring cache定义的接口方法说明和注解中的属性说明 springboot+spring cache...
    99+
    2024-04-02
  • 为什么使用redis做缓存
    使用redis做缓存的原因:redis数据存在内存中,因此速度会比较快。支持丰富数据类型,例如string,list,set,sorted set等等。redis对事务是部分支持的,如果是在入队时报错,那么都不会执行;在非入队时报错,那么成...
    99+
    2024-04-02
  • SpringBoot中怎么使用Redis做缓存
    在SpringBoot中使用Redis做缓存可以通过以下步骤实现: 添加依赖:首先在pom.xml文件中添加Spring Data...
    99+
    2024-04-09
    SpringBoot Redis
  • Redis做预定库存缓存功能设计使用
    目录一、业务背景二、库存管理方案(Redis)三、进阶场景&库存管理方案五、存储优化六、总结最近在自己的工作中,把其中一个PHP项目的缓存从以前的APC缓存逐渐切换到Redi...
    99+
    2024-04-02
  • 使用Redis做缓存的原因有哪些
    这篇文章给大家分享的是有关使用Redis做缓存的原因有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。对Redis,百度百科给出的的解释是“Redis(Remote Dicti...
    99+
    2024-04-02
  • 浅谈SpringCache与redis集成实现缓存解决方案
    缓存可以说是加速服务响应速度的一种非常有效并且简单的方式。在缓存领域,有很多知名的框架,如EhCache 、Guava、HazelCast等。Redis作为key-value型数据库,由于他的这一特性,Redis也成为一种流行的数据缓存工具...
    99+
    2023-05-30
    spring cache redis
  • 如何使用SpringCache进行缓存数据库查询
    这篇文章给大家分享的是有关如何使用SpringCache进行缓存数据库查询的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。SpringCache进行缓存数据库查询1、在SpringBoot的启动类上添加注解@Ena...
    99+
    2023-06-25
  • 使用SpringCache进行缓存数据库查询方式
    目录SpringCache进行缓存数据库查询1、在SpringBoot的启动类上添加注解@EnableCaching2、在service的方法上添加对应的注解SpringCache ...
    99+
    2024-04-02
  • 分布式医疗挂号系统SpringCache与Redis为数据字典添加缓存
    目录一、SpringCache介绍二、项目集成Spring Cache1.添加缓存相关依赖2.添加redis配置类3.添加redos配置三、数据字典配置Spring Cache1.缓...
    99+
    2024-04-02
  • redis怎么做缓存机制
    Redis是一个开源的、高性能的键值数据库,它可以用作缓存机制来提高系统的访问速度。以下是使用Redis作为缓存机制的一些步骤:1....
    99+
    2023-09-06
    redis
  • 怎么用Redis做预定库存缓存功能
    这篇文章主要介绍了怎么用Redis做预定库存缓存功能的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么用Redis做预定库存缓存功能文章都会有所收获,下面我们一起来看看吧。一、业务背景为了略去我们公司项目背景,...
    99+
    2023-06-29
  • redis适合做缓存的原因
    这篇文章给大家分享的是有关redis适合做缓存的原因的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。   Redis是一款内存高速缓存数据库;数据模型为:key...
    99+
    2024-04-02
  • redis怎么做缓存服务器
    redis 作为缓存服务器的答案:redis 是一款开源、高性能、分布式的键值存储,可作为缓存服务器使用。原因:高性能:在内存中存储数据以实现快速访问。低延迟:优化的数据结构和操作以最小...
    99+
    2024-04-08
    redis 数据访问 键值对
  • 在项目中使用redis做缓存的一些思路
    目录在项目中redis做缓存的一些思路首先,缓存的对象有三种本人走过的一些弯路为什么没用Redis做缓存使用Table作本地缓存使用Redis作缓存让我们来思考一下下面几个问题那么使...
    99+
    2024-04-02
  • Redis缓存在系统中用来做什么
    本篇内容介绍了“Redis缓存在系统中用来做什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、缓存在系统中用来做什么? 少量数据存储,高...
    99+
    2023-06-02
  • SpringCache与Redis结合的使用方式
    目录Redis创建Spring项目集成RedisCache部分代码@Cacheable 作用和配置方法@CacheEvict 作用和配置方法前不久做了一个需要查询多,更新少的功能,老...
    99+
    2024-04-02
  • 添加redis缓存的方法
    这期内容当中小编将会给大家带来有关添加redis缓存的方法,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。redis常本用来作为缓存服务器。缓存的好处是减少服务器的压力,数...
    99+
    2024-04-02
  • 使用redis缓存的优势
    今天就跟大家聊聊有关使用redis缓存的优势,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。redis(全称:Remote Dictionary Se...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作