当前位置: 首页 > news >正文

SpringCache的介绍和入门案例

文章目录

  • 概述
  • 常用注解
  • 入门案例

概述

Spring Cache是Spring框架提供的一个缓存抽象层,用于在应用程序中实现缓存的功能。它通过在方法执行前检查缓存中是否已经存在所需数据,如果存在则直接返回缓存中的数据,如果不存在则执行方法体,将方法的返回值存储到缓存中,以便后续的请求可以直接从缓存中获取数据。

Spring Cache的主要特性如下:

  1. 声明式缓存:通过使用注解或XML配置的方式,可以很方便地将缓存逻辑应用到方法上。开发人员只需要在需要被缓存的方法上添加相应的注解,如@Cacheable、@CachePut等,Spring框架会自动处理缓存的读取和更新操作。

  2. 缓存注解支持:Spring Cache提供了多种缓存注解,包括@Cacheable、@CachePut、@CacheEvict等,用于标记具体的方法需要进行缓存的读取、更新和清除操作。通过这些注解,开发人员可以灵活地控制缓存的行为和策略。

  3. 多种缓存技术支持:Spring Cache支持多种常见的缓存技术,如Ehcache、Redis、Caffeine等。开发人员可以根据实际需求选择合适的缓存提供商,并通过简单的配置即可接入相应的缓存技术。

  4. 缓存管理器:Spring Cache提供了缓存管理器的抽象,可以统一管理和配置应用程序中的缓存。开发人员可以通过配置文件或编程方式定义缓存管理器的属性和行为,以满足不同环境和需求的缓存配置。

  5. 可扩展性:Spring Cache具有良好的可扩展性,支持自定义缓存注解和缓存操作的实现。开发人员可以根据自己的需求扩展并定制Spring Cache的功能,以适应特定的业务场景。

使用Spring Cache可以有效地减少重复计算和数据库访问等耗时操作,提升系统的响应速度和性能。它提供了简单而强大的API和注解,使得开发人员能够更加轻松地实现缓存功能,并与Spring框架的其他模块无缝集成。

常用注解

在SpringCache中提供了很多缓存操作的注解,常见的是以下的几个:

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

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

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

入门案例

下面是一个使用Redis作为缓存技术的Spring 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>

接下来,你需要在Spring Boot的配置文件(如application.properties或application.yml)中添加Redis的连接信息,例如:

spring.redis.host=localhost
spring.redis.port=6379
spring.redis.password=

然后,你可以创建一个UserService接口,用于定义用户相关的服务方法:

public interface UserService {User getUserById(Long id);
}

接着,创建一个实现了UserService接口的UserServiceImpl类:

@Service
public class UserServiceImpl implements UserService {@Override@Cacheable(value = "users", key = "#id")public User getUserById(Long id) {// 模拟从数据库或其他数据源获取用户信息System.out.println("查询数据库获取用户信息,用户ID:" + id);return new User(id, "John Doe");}
}

在上述代码中,我们使用了@Cacheable(value = "users", key = "#id")注解来标记getUserById方法需要进行缓存。这里的"users"是缓存名称,表示将结果缓存到名为"users"的缓存中,key = "#id"表示缓存的key是方法的参数id。

最后,你可以编写一个简单的测试类来验证缓存的效果:

@RunWith(SpringRunner.class)
@SpringBootTest
public class UserServiceTest {@Autowiredprivate UserService userService;@Testpublic void testGetUserById() {// 第一次调用,会执行方法内部的逻辑,从数据库中查询用户信息User user1 = userService.getUserById(1L);System.out.println(user1);// 第二次调用,应该从缓存中获取用户信息,不再执行方法内部的逻辑User user2 = userService.getUserById(1L);System.out.println(user2);}
}

在上述测试代码中,第一次调用getUserById方法时,会执行方法内部的逻辑,从数据库中查询用户信息。而第二次调用时,由于结果已经缓存在名为"users"的缓存中,所以直接从缓存中获取用户信息,不再执行方法内部的逻辑。

通过以上方式,我们就可以使用Redis作为缓存技术来实现方法级别的缓存功能了。当然,在实际项目中,你还可以根据需求进一步配置缓存管理器、缓存策略等。

http://www.lryc.cn/news/122853.html

相关文章:

  • 闪马智能又上榜!
  • C++中的四种类型转换(Type Casting)方式
  • Linux系列:从0到1用Docker部署springboot项目
  • zabbix监控mysql数据库、nginx、Tomcat
  • 深入探索二叉树算法:理解、构建和应用C语言
  • (css)点击前隐藏icon图表 点击后显示
  • Tomcat的动静分离以及多实例部署
  • uniapp+vue3项目中使用vant-weapp
  • WordPress:实现发布文章自动添加TAG标签
  • ubuntu下FFmpeg安装和使用以及CMakeLists.txt模板
  • 数据结构顺序表和链表(超详细)
  • free 查看 buff/cache 很大,处理方法
  • 【Quarkus技术系列】「云原生架构体系」在云原生时代下的Java“拯救者”是Quarkus,那云原生是什么呢?
  • DHCP的工作原理
  • display:flex;兼容浏览器写法
  • 三、python Django ORM postgresql[数据定时备份、数据恢复]
  • c++字符串函数
  • 使用OkHttp发送POST请求的几种方式
  • 时序预测 | MATLAB实现EEMD-GRU、GRU集合经验模态分解结合门控循环单元时间序列预测对比
  • 学习笔记整理-JS-04-流程控制语句
  • stable-diffusion-webui 界面汉化
  • 问道管理:信创概念走势活跃,恒银科技斩获四连板
  • centos 7镜像(iso)下载图文教程(超详细)
  • 使用Druid,以jdbc方式配置多数据源
  • RabbitMQ基础(2)——发布订阅/fanout模式 topic模式 rabbitmq回调确认 延迟队列(死信)设计
  • 2. VisionOS平台概述
  • MySql存储过程详解
  • CRM 系统实施风险分析
  • 保持城市天际线(力扣)贪心 JAVA
  • 电路综合原理与实践---T衰减与PI衰减的详细计算理论与设计仿真