SpringCache的介绍和入门案例

news/2025/2/26 4:53:23

文章目录

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

概述

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接口,用于定义用户相关的服务方法:

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

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

java">@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。

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

java">@RunWith(SpringRunner.class)
@SpringBootTest
public class UserServiceTest {

    @Autowired
    private UserService userService;

    @Test
    public 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.niftyadmin.cn/n/4936941.html

相关文章

【运维】Zabbix简介及其应用领域

文章目录 1. Zabbix的背景与起源1.1. 监控工具的重要性为什么企业和个人需要监控工具&#xff1f;常见的监控挑战与需求 1.2. Zabbix的诞生背景Zabbix的发展历程Zabbix与其他监控工具的对比 2. Zabbix的核心功能2.1. 数据收集支持的数据收集方法数据的存储与历史记录 2.2. 可视…

隐私政策与用户协议 Privacy statement and User agreement——《小小数学》

《小小数学》App 会按照本隐私权政策的规定使用和披露您的个人信息。 但《小小数学》App 将以高度的勤勉、审慎义务对待这些信息。除本隐私权政策另有规定外&#xff0c;在未征得您事先许可的情况下&#xff0c;《小小数学》App 不会将这些信息对外披露或向第三方提供。 《小…

从零学算法(非官方题库)

输入两棵二叉树A和B&#xff0c;判断B是不是A的子结构。(约定空树不是任意一个树的子结构) B是A的子结构&#xff0c; 即 A中有出现和B相同的结构和节点值。 例如: 给定的树 A:3/ \4 5/ \1 2给定的树 B&#xff1a;4 / 1返回 true&#xff0c;因为 B 与 A 的一个子树拥有相…

nlohmann json:通过[ ]运算符读取设置object/array

除了可以通过at,还可以通过[ ]运算符来读取和设置object/array #include <iostream> #include <nlohmann/json.hpp> using namespace std; using json = nlohmann::json;int main() {json data = R"({"name": "xiaoming","age&quo…

Azure创建第一个虚拟机

首先&#xff0c;登录到 Azure 门户 (https://portal.azure.com/)。在 Azure 门户右上角&#xff0c;点击“虚拟机”按钮&#xff0c;并点击创建&#xff0c;创建Azure虚拟机。 在虚拟机创建页面中&#xff0c;选择所需的基本配置&#xff0c;包括虚拟机名称、操作系统类型和版…

make -C

make -C $MAXIEYE_BUILD_DIR p$1 clean -j$JOBS_NPROC-C 大写&#xff0c;切换到指定目录再执行 make 过程&#xff0c;makefile 在这个指定目录里面

自主学习库简化智能代理创建

观看当今毁灭人类的智能代理玩复杂的视频游戏可能很有趣 - 但创建一个是另一回事。构建有效的智能代理需要设置大量超参数来塑造环境、建立奖励等。来自马萨诸塞大学阿默斯特分校的一组研究人员试图通过他们新的自主学习图书馆项目来简化这一过程。 自治学习库是 PyTorch 的深…

Go Web--Go Module

目录 一、Go Module 1、开启Go Module 2、Go Module基本操作 3、使用GoLand创建Go Module项目 4、GoLand配置File Watchers 一、Go Module Go Module包管理工具----相当于Maven 1.11版本引入 1.12版本正式支持 告别GOPATH&#xff0c;使用Go Module管理项目&#xff0c…