Spring Cache的介绍以及怎么使用(redis)

这篇具有很好参考价值的文章主要介绍了Spring Cache的介绍以及怎么使用(redis)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Spring Cache

1、Spring Cache介绍

  • Spring Cache是一个框架,实现了基于注解的缓存功能,只需要简单地加一个注解,就能实现缓存功能.
  • Spring Cache提供了一层抽象,底层可以切换不同的cache实现。具体就是通过CacheManager接口来统一不同的缓存技术。CacheManager是Spring提供的各种缓存技术抽象接口。

针对不同的缓存技术需要实现不同的CacheManager:

CacheManager 描述
EhCacheCacHManager 使用EhCache作为缓存技术
GuavaCacheManager 使用Google的GuavaCache作为缓存技术
RedisCacheManager 使用Redis作为缓存技术

2、Spring Cache常用注解

注解 说明
@EnableCaching 开启缓存注解功能
@Cacheable 在方法执行前spring先查看缓存中是否有数据,如果有数据,则直接返回缓存数据;若没有数据,调用方法并将方法返回值放到缓存中
@CachePut 将方法的返回值放到缓存中
@cacheEvict 将一条或多条数据从缓存中删除

在spring boot项目中,使用缓存技术只需在项目中导入相关缓存技术的依赖包,并在启动类上使用@EnableCaching开启缓存支持即可。

例如,使用Redis作为缓存技术,只需要导入Spring data Redis的maven坐标即可。

  • 我们在使用简单的缓存技术的时候不用单独映入相应的依赖,使用spring-boot-starter-web这个包即可,但是要使用redis作为缓存就需要额外的引入依赖:

           <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-cache</artifactId>
            </dependency>
    
2.1、EnableCaching注解

在启动类上加上注解@EnableCaching

2.2、CachePut注解
@Autowired
private CacheManager cacheManager;

@Autowired
private UserService userService;

/**
 *  CachePut:将方法的返回值放入缓存
 *  value:缓存名称  每个缓存可以有多个key
 *  key:缓存的key  #result.id:动态生成keyName进行缓存
 *
 *
 */
@CachePut(value = "userCache",key="#result.id")
//    @CachePut(value = "userCache",key="#user.name")  //将user->name作为缓存名
//    @CachePut(value = "userCache",key="#user.id")   //将user->id作为缓存名
@PostMapping
public User save(User user){
    userService.save(user);
    return user;
}

key值参数引用(SpEL动态获取)的说明:

Spring Cache的介绍以及怎么使用(redis),Redis,spring,redis,spring boot

该注解在没有缓存配置(如redis)的时候,会将数据缓存在ConcurrentMap里面,但是此缓存操作不具有持久化的储存,在服务重启之后会数据丢失。解决方法是使用Redis等缓存中间件。

2.3、CacheEvict注解
  • DELETE
/**
 *  CacheEvict:清理指定缓存
 *  value:缓存名称  每个缓存可以有多个key
 *  key:缓存的key  #result.id:动态生成keyName进行缓存
 */
@CacheEvict(value = "userCache",key = "#id")
//@CacheEvict(value = "userCache",key = "#p0")
//@CacheEvict(value = "userCache",key = "#root.args[0]")
// 上述三种方式都是相同的效果,动态获取id的参数作为缓存的唯一标识
@DeleteMapping("/{id}")
public void delete(@PathVariable Long id){
    userService.removeById(id); 
}
  • UPDATE
@CacheEvict(value = "userCache",key = "#user.id")
//@CacheEvict(value = "userCache",key = "#p0.id")
//@CacheEvict(value = "userCache",key = "#root.args[0].id")
//@CacheEvict(value = "userCache",key = "#result.id")
@PutMapping
public User update(User user){
    userService.updateById(user);
    return user;
}
2.4、Cacheable注解
    /**
     * Cacheable:在方法执行前spring先查看缓存中是否有数据,
     * 如果有数据,则直接返回缓存数据;若没有数据,调用方法并将方法返回值放到缓存中;
     * value:缓存名称  每个缓存可以有多个key
     * key:缓存的key  #result.id:动态生成keyName进行缓存
     * condition:满足条件就进行缓存,无法使用#result
     * unless:满足条件就不进行缓存,可以使用#result-->看源码注解
     */ 
    @Cacheable(value = "userCache", key = "#id", condition = "#unless == null")
    @GetMapping("/{id}")
    public User getById(@PathVariable Long id) {
        User user = userService.getById(id);
        return user;
    }

在方法执行前spring先查看缓存中是否有数据,如果有数据,则直接返回缓存数据;若没有数据,调用方法并将方法返回值放到缓存中。

@Cacheable(value = "userCache", key = "#user.id+'_'+#user.name")
//多个变量的拼接
@GetMapping("/list")
public List<User> list(User user) {
    LambdaQueryWrapper<User> queryWrapper = new LambdaQueryWrapper<>();
    queryWrapper.eq(user.getId() != null, User::getId, user.getId());
    queryWrapper.eq(user.getName() != null, User::getName, user.getName());
    List<User> list = userService.list(queryWrapper);
    return list;
}

3、Spring Cache使用方式–redis

在Spring Boot项目中使用Spring Cache的操作步骤(使用redis缓存技术):

  • 1、导入maven坐标
    spring-boot-starter-data-redisspring-boot-starter-cache
       <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-cache</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>

2、配置application.yml

spring:
  redis:
    host: 127.0.0.1
    port: 6379
    password: 123456
    database: 0
  cache:
    redis:
      time-to-live: 1800000 #设置缓存过期时间,可选

3、在启动类上加入@EnableCaching注解,开启缓存注解功能
4、在Controller的方法上加入@Cacheable、@CacheEvict等注解,进行缓存操作

Demo项目源码:SpringCache-Demo文章来源地址https://www.toymoban.com/news/detail-676404.html

到了这里,关于Spring Cache的介绍以及怎么使用(redis)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Spring项目使用Redis限制用户登录失败的次数以及暂时锁定用户登录权限

    前两天被面试到这个问题,最初回答的不是很合理,登录次数这方面记录还一直往数据库上面想,后来感觉在数据库中加一个登录日志表,来查询一段时间内用户登录的次数,现在看来,自己还是太年轻了,做个登录限制肯定是为了防止数据库高并发,加一个表来记录登录日

    2024年02月12日
    浏览(50)
  • spring boot集成redis,以及配置database不生效问题

    备注:记录一次spring-boot + redis 配置redis.database后,仍然使用db0默认库的情况。 完成以上配置,即redis已经正常集成进入项目。 完成以上配置,即可正常使用了       如果是单独仅集成redis,database 配置是肯定生效的,因为没有影响,这里记录一个遇到的情景:       即

    2024年01月19日
    浏览(46)
  • redis(9):spring里面使用redis

    1 创建一个mave项目 自行创建一个maven项目 2 修改pom.xml

    2024年02月16日
    浏览(29)
  • Spring Boot 使用 Redis

    Java Java Java Java Java Java 4,乱码的问题 自定义序列化工具 为什么要自定话应该序列化工具,因为他自己提供的不是很好,所以我们要自己定义一个,这样的话可以把java对象转化成json和字节码存入Redis 里,反序列化就是把json和字节码转化为java对象,泛型指定为  Object.class  表

    2024年04月08日
    浏览(35)
  • Spring Data Redis的使用

    解决方法为在Redis-x64-3.2.100目录下打开两个cmd窗口,分别输入 命令redis-server.exe redis.windows.conf 和 命令redis-cli ,即可成功连接。   首先在maven的pom文件中引入 Spring Data Redis 模块,代码如下。 然后,在springboot的配置文件中写入redis配置,代码如下。 然后,处理keys的序列化问题

    2024年02月09日
    浏览(39)
  • Spring Boot中使用Redis

    目录 1.依赖 2.依赖关系 3.配置 4.RedisTemplate 5.基础操作 6.事务 maven依赖如下,需要说明的是,spring-boot-starter-data-redis里默认是使用lettuce作为redis客户端的驱动,但是lettuce其实用的比较少,我们常用的还是jedis作为客户端的驱动,所以这里排除掉lettuce,引入jedis: spring data redi

    2023年04月11日
    浏览(101)
  • Spring Boot 中使用 Redis

    redis 安装、配置,启动:(此处以云服务器上进行说明) 1. 添加 pom 2. 添加配置 3. 导入 redis 工具类 PS:redis 工具类对常用操作进行了封装,可自行研究食用。 4. 测试

    2023年04月14日
    浏览(38)
  • 常用的缓存工具有ehcache、memcache和redis,这里介绍spring中ehcache的配置。

    常用的缓存工具有ehcache、memcache和redis,这里介绍spring中ehcache的配置。 1.在pom添加依赖: 2.在applicationContext.xml添加命名空间: 3.在applicationContext.xml中配置ehcache: 4.创建ehcache的配置文件ehcache-setting.xml: 这里我们配置了自定义缓存cacheTest,10秒过期。 cache元素的属性: name:缓

    2024年02月16日
    浏览(41)
  • spring boot中redis的使用

    首先,需要在 pom.xml 文件中添加Redis依赖: 这个依赖包含了Spring Data Redis,以及Jedis和Lettuce这两种Redis客户端的实现。 在SpringBoot项目中,可以通过在 application.properties 或 application.yml 文件中配置Redis连接信息。以下是一个示例: 其中, host 和 port 分别是Redis服务器的地址和端

    2024年02月09日
    浏览(30)
  • Spring Cache 介绍

    Spring Cache 是 Spring 提供的的缓存解决方案,它并非是一个具体的缓存实现,而是和 JSR107 类似的一套缓存规范,基于注解并与 Spring 的无缝集成。本文主要介绍其基本概念及简单使用。 Spring Cache 是 Spring 提供的一种缓存抽象机制,用于简化应用中的缓存操作。它通过将方法的

    2024年04月22日
    浏览(27)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包