springboot Redis 缓存
1,先整合 redis 和 mybatis
步骤一: springboot 整合 redis
步骤二: springboot 整合 mybatis
2,启动类添加 @EnableCaching 注解,开启缓存
因为缓存获取不到数据要到数据库获取,所以还要扫描 mybatis 接口路径
@SpringBootApplication
@MapperScan("com.test.Idao")
@EnableCaching
public class StringbootRedisCacheApplication { public static void main(String[] args) {
SpringApplication.run(StringbootRedisCacheApplication.class, args);
}
}
3,增(获取)、删、改缓存注解
@Cacheable 获取缓存 ---- 该注解用于方法上,方法不一定执行
@Cacheable(cacheNames = "user", key="#id"),在 redsi 中 key 是 cacheNames 和 key 拼接而成,如果 id 为 1 ,具体的 key 为:user::1
cacheNames 随意指定,key 只能是来自于当前方法的参数
会根据 key 先到 redis 获取数据,如果没获取到,就运行方法到数据库取得数据并放入 redis,下次调用该方法就不会到数据库了
@CachePut 更新缓存 ---- 该注解用于方法上,方法每次都会执行
配置和 @Cacheable 一致
先到数据库修改数据,再根据 key 到 redis 中查询,如果有数据就更新,如果没有就添加,值是方法的返回值
@CacheEvict 删除缓存 ---- 该注解用于方法上,方法每次都会执行
配置和 @Cacheable 一致
根据 key 到 redis 中查询,如果有数据就删除
@CacheConfig ---- 该注解用于类上,用于简化上面 3 个配置,可以一次性定义 cacheNames ,方法上配置别的属性即可
示例
// key 只能是 id,因为参数是 id
@Cacheable(cacheNames="user", key="#id")
public User getUserById(int id){} // 如果参数是对象,key 可以是参数的任意属性名
@CachePut(cacheNames="user", key="#user.id")
public User updateUserById(User user){} // 如果参数是基本类型,可以不配置 key,默认就是该参数作为 key
@CacheEvict(cacheNames="user")
public User deleteUserById(int id){} // CacheConfig 配置了 cacheNames="user",所有方法的cacheNames都是 user
@CacheConfig(cacheNames="user")
public class UserService{
@Cacheable
public User getUserById(int id){}
@CachePut(key="#user.id")
public User updateUserById(User user){}
}
坑:
1,如果 key 不是唯一的(比如用户表中的 name 字段作为缓存的 key ),结果就会在缓存中一个 key 查出一个 list ,这是修改要特别注意因为 @CacheEvict 注解会把该方法的返回值作为 value 覆盖原来的 value,我有个这样的需求,我的解决办法是:修改方法不做缓存操作,方法执行完后调用一个方法来清除原来的缓存,这样能解决数据的准确性,但是每当修改后要再查询数据的话就需要把 mysql 数据放入 redis
2,在 pojo 类上不能使用 @Repository 注解,建议使用 @Component
3,各个缓存方法只能在外部调用才会生效(比如在 service 层定义,在 controller 层调用)
springboot Redis 缓存的更多相关文章
- springboot redis 缓存对象
只要加入spring-boot-starter-data-redis , springboot 会自动识别并使用redis作为缓存容器,使用方式如下 gradle加入依赖 compile(" ...
- SpringBoot Redis缓存 @Cacheable、@CacheEvict、@CachePut
文章来源 https://blog.csdn.net/u010588262/article/details/81003493 1. pom.xml <dependency> <gro ...
- springboot + redis缓存使用
[参照资料] 1.spring boot 官网文档 2.https://www.cnblogs.com/gdpuzxs/p/7222309.html [项目结构] [pom.xml配置] <?x ...
- 从.Net到Java学习第七篇——SpringBoot Redis 缓存穿透
从.Net到Java学习系列目录 场景描述:我们在项目中使用缓存通常都是先检查缓存中是否存在,如果存在直接返回缓存内容,如果不存在就直接查询数据库然后再缓存查询结果返回.这个时候如果我们查询的某一个数 ...
- 微服务-Springboot+Redis缓存管理接口代码实现
废话少说,上代码,结合代码讲解: 一.创建maven工程:导入依赖: <packaging>war</packaging><!--修改jdk的版本--><pr ...
- springboot redis 缓存跨域丢失问题
对于前后端分离的项目,在开发阶段经常会遇到跨域的问题. 1.首先,对于后台的处理方式,第一种是用 @CrossOrigin 注解,@crossorigin是后端SpringMVC框架(需4.2版本以上 ...
- spring-boot的spring-cache中的扩展redis缓存的ttl和key名
原文地址:spring-boot的spring-cache中的扩展redis缓存的ttl和key名 前提 spring-cache大家都用过,其中使用redis-cache大家也用过,至于如何使用怎么 ...
- SpringBoot学习笔记(6) SpringBoot数据缓存Cache [Guava和Redis实现]
https://blog.csdn.net/a67474506/article/details/52608855 Spring定义了org.springframework.cache.CacheMan ...
- java框架之SpringBoot(11)-缓存抽象及整合Redis
Spring缓存抽象 介绍 Spring 从 3.1 版本开始定义了 org.springframework.cache.Cache 和 org.springframework.cache.Cache ...
随机推荐
- 【app】Appium-desktop界面介绍
在appium主界面的host输入127.0.0.1 然后点击Start Server即可开启appium server 我们来说说advanced选项 Server Address: 为appium ...
- Ubuntu 18.04搭建Git服务器
学习链接:博客园.廖雪峰 一 前言 前面已经贴了两个链接,为什么还要再写一篇呢,因为可能由于个人能力问题,我觉得上面两篇写的都有点简略,有些地方不太好理解,并不能一次性成功搭建,所以想根据自己踩过的坑 ...
- asp.net core 2.0发布到IIS流程及报错解决方案
我这是个新装的服务器,没有安装任何软件. 一.发布流程 1.安装AspNetCoreModule托管模块,同时会自动安装..net core runtime DotNetCore.2.0.8-Wi ...
- Android--多线程之进程与线程
前言 对于Android程序中,使用多线程的技术是必不可少的,就拿之前最简单的例子来说明,对于Android4.0+的应用而言,访问网络必须另起线程才可以访问.本片博客介绍Android下进程和线程, ...
- Talk In Web Security(安全世界观): Devleping a Secure WebSite
Writer:BYSocket(泥沙砖瓦浆木匠) 微博:BYSocket 豆瓣:BYSocket Reprint it anywhere u want. Why to write about Web ...
- 前端测试框架Jest系列教程 -- Expect(验证)
写在前面 在编写测试时,我们通常需要检查值是否满足某些条件,Jest中提供的expect允许你访问很多“Matchers”,这些“匹配器”允许您验证不同的东西. Expect 可以验证什么 Jest中 ...
- Linux两台主机之间建立信任(ssh免密码)
背景: 有时候我们在两个主机之间复制文件的时候,提示输入密码,很不方便,那如何免密码复制呢?,就是使用通过linux公钥和秘钥,建立双机信任关系. 在整理之前,我先说下ssh免密码的要点 : 你想免密 ...
- 云数据库POLARDB优势解读之①——10分钟了解
什么是POLARDB POLARDB 是阿里云自研的下一代关系型分布式数据库,100%兼容MySQL,之前使用MySQL的应用程序不需要修改一行代码,即可使用POLARDB. POLARDB在运行形态 ...
- solr调用lucene底层实现倒排索引源码解析
1.什么是Lucene? 作为一个开放源代码项目,Lucene从问世之后,引发了开放源代码社群的巨大反响,程序员们不仅使用它构建具体的全文检索应用,而且将之集成到各种系统软件中去,以及构建Web应用, ...
- 深入理解Java虚拟机阅读心得(三)
Java中提倡的自动内存管理最终可以归结为自动化的解决两个问题: 给对象分配内存 回收分配给对象的内存 先说说回收这一方面的两个主要知识点 一.垃圾收集算法 1.标记-清理算法 首先标记出所有需要回收 ...