Spring基于注解整合Redis

本文涉及的产品
云数据库 Redis 版,标准版 2GB
推荐场景:
搭建游戏排行榜
云原生内存数据库 Tair,内存型 2GB
简介: 【8月更文挑战第5天】

Spring基于注解整合Redis

Redis是一种内存中的数据结构存储系统,被广泛用于缓存、消息队列等场景。Spring提供了对Redis的整合,使得在Spring应用中使用Redis变得更加方便和灵活。本文将介绍如何使用Spring注解来整合Redis。

1. 添加依赖

首先,在pom.xml文件中添加以下依赖,以引入Spring Data Redis:

xmlCopy code
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

2. 配置Redis连接

application.properties文件中配置Redis连接信息,例如:

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

你可以根据实际情况修改以上配置项。

3. 创建Redis配置类

创建一个Redis配置类,用于配置Redis相关的bean。我们可以使用@Configuration注解来标识这是一个配置类,并使用@EnableCaching注解来开启Spring缓存支持。

javaCopy code
@Configuration
@EnableCaching
public class RedisConfig {
    @Bean
    public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory connectionFactory) {
        RedisTemplate<String, Object> template = new RedisTemplate<>();
        template.setConnectionFactory(connectionFactory);
        return template;
    }
    @Bean
    public CacheManager cacheManager(RedisConnectionFactory connectionFactory) {
        RedisCacheManager cacheManager = RedisCacheManager.create(connectionFactory);
        return cacheManager;
    }
}

上述配置创建了一个名为redisTemplateRedisTemplate实例,并配置了连接工厂。另外,我们还创建了一个名为cacheManagerCacheManager实例,用于管理缓存。

4. 使用注解操作Redis

现在,我们可以在Spring应用中使用注解来操作Redis。以下是一些常用的注解:

4.1 @Cacheable

@Cacheable注解可以应用在方法上,用于开启缓存。当方法被调用时,Spring会先检查缓存中是否存在对应的结果,如果存在,则直接返回缓存的结果;如果不存在,则执行该方法,并将结果存入缓存。

javaCopy code
@Cacheable(value = "users", key = "#userId")
public User getUserById(String userId) {
    // 从数据库或其他数据源获取用户信息
    return userRepository.findById(userId);
}

以上示例中,@Cacheable注解应用在getUserById方法上,指定缓存名称为users,并根据userId作为缓存的key。

4.2 @CachePut

@CachePut注解可以应用在方法上,用于更新缓存。当方法被调用时,Spring会先执行该方法,并将结果存入缓存,而不会去检查缓存中是否已存在。

javaCopy code
@CachePut(value = "users", key = "#user.id")
public User saveUser(User user) {
    // 保存用户信息到数据库或其他数据源
    return userRepository.save(user);
}

以上示例中,@CachePut注解应用在saveUser方法上,将返回的用户对象存入缓存,并以user.id作为缓存的key。

4.3 @CacheEvict

@CacheEvict注解可以应用在方法上,用于删除缓存。当方法被调用时,Spring会从缓存中删除对应的结果。

javaCopy code
@CacheEvict(value = "users", key = "#userId")
public void deleteUser(String userId) {
    // 从数据库或其他数据源删除用户信息
    userRepository.deleteById(userId);
}

以上示例中,@CacheEvict注解应用在deleteUser方法上,根据userId从缓存中删除对应的用户。

4.4 使用SpEL表达式

在上述示例中,我们使用了SpEL(Spring Expression Language)表达式来动态地生成缓存的key。例如,key = "#userId"中的#表示后面跟随的是一个SpEL表达式。 你可以使用SpEL表达式来引用方法参数、调用方法、访问类的属性等,以灵活地生成缓存的key。

5. 使用Redis作为缓存存储

上述示例中,我们使用了默认的RedisTemplate来操作Redis。除了默认的使用方式外,你还可以使用Spring提供的@EnableRedisRepositories注解和RedisRepository接口来实现基于注解的Redis缓存存储。 具体的使用方式可以参考Spring Data Redis的文档。

电子商务网站,我们可以使用Redis作为商品信息的缓存,以提高访问速度和减轻数据库的压力。以下是一个使用Spring注解整合Redis的示例代码:

javaCopy code
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cache.annotation.CacheEvict;
import org.springframework.cache.annotation.Cacheable;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Service;
@Service
public class ProductService {
    @Autowired
    private ProductRepository productRepository;
    @Autowired
    private RedisTemplate<String, Object> redisTemplate;
    @Cacheable(value = "products", key = "#productId")
    public Product getProductById(String productId) {
        // 先检查缓存
        Product cachedProduct = (Product) redisTemplate.opsForHash().get("products", productId);
        if (cachedProduct != null) {
            return cachedProduct;
        }
        
        // 从数据库获取商品信息
        Product product = productRepository.findById(productId);
        
        // 将商品信息存入缓存
        redisTemplate.opsForHash().put("products", productId, product);
        return product;
    }
    @CacheEvict(value = "products", key = "#productId")
    public void deleteProduct(String productId) {
        // 从数据库删除商品信息
        productRepository.deleteById(productId);
        
        // 从缓存中删除商品信息
        redisTemplate.opsForHash().delete("products", productId);
    }
}

在上述示例代码中,我们定义了一个ProductService类,它使用@Service注解标识为一个Spring服务。在方法getProductById中,我们使用了@Cacheable注解来开启缓存,并指定了缓存名称为products,key为productId。首先,我们先从缓存中检查商品信息是否存在,如果存在则直接返回缓存的商品对象。如果缓存中不存在该商品信息,则从数据库中获取商品信息,并将其存入缓存中。在方法deleteProduct中,我们使用了@CacheEvict注解来删除缓存,将指定的商品信息从缓存中删除。这样,当多次调用getProductById方法时,如果该商品信息已存在于缓存中,则直接从缓存中获取,避免了频繁地访问数据库,提升了访问速度和性能。

在使用Spring集成Redis时,需要进行相应的配置。Spring提供了一个RedisTemplate类来支持与Redis进行交互。下面是一个典型的Spring Redis配置文件示例:

xmlCopy code
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:p="http://www.springframework.org/schema/p"
       xmlns:util="http://www.springframework.org/schema/util"
       xsi:schemaLocation="
            http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
            http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
            http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util.xsd">
    <!-- 配置 Redis 连接池 -->
    <bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
        <!-- 设置最大连接数 -->
        <property name="maxTotal" value="100" />
        <!-- 设置最大空闲连接数 -->
        <property name="maxIdle" value="10" />
        <!-- 设置最大等待时间,单位毫秒 -->
        <property name="maxWaitMillis" value="5000" />
    </bean>
    <!-- 配置 Redis 连接工厂 -->
    <bean id="jedisConnectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory"
          p:hostName="localhost" p:port="6379" p:poolConfig-ref="jedisPoolConfig" />
    <!-- 配置 RedisTemplate -->
    <bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate"
          p:connectionFactory-ref="jedisConnectionFactory">
        <property name="keySerializer">
            <bean class="org.springframework.data.redis.serializer.StringRedisSerializer" />
        </property>
        <property name="hashKeySerializer">
            <bean class="org.springframework.data.redis.serializer.StringRedisSerializer" />
        </property>
        <property name="valueSerializer">
            <bean class="org.springframework.data.redis.serializer.JdkSerializationRedisSerializer" />
        </property>
    </bean>
    <!-- 其他配置 -->
</beans>

上述配置文件主要包含以下几点:

  1. 配置Redis连接池(jedisPoolConfig):Redis连接池用于管理连接到Redis服务器的连接对象。在这里,我们可以配置连接池的最大连接数、最大空闲连接数和最大等待时间等参数,以满足应用程序的需求。
  2. 配置Redis连接工厂(jedisConnectionFactory):Redis连接工厂用于创建与Redis服务器的连接。在这里,我们指定了Redis服务器的主机名和端口,并引用了之前配置的连接池对象。
  3. 配置RedisTemplate(redisTemplate):RedisTemplate是Spring用于与Redis进行交互的核心类。在这里,我们指定了连接工厂对象,以及key和value的序列化方式。在示例中,key和hashKey使用了StringRedisSerializer进行序列化,value使用了JdkSerializationRedisSerializer进行序列化。根据需要,你还可以选择其他的序列化方式,如Jackson2JsonRedisSerializer、GenericToStringSerializer等。 通过以上配置,我们可以在Spring应用程序中注入redisTemplate对象,并使用它进行Redis数据的读写操作。例如,通过调用redisTemplate.opsForValue().set(key, value)来将数据存入Redis,或通过调用redisTemplate.opsForValue().get(key)来从Redis中获取数据。

结论

本文介绍了如何使用Spring注解来整合Redis,并使用缓存相关的注解来简化对Redis的操作。通过合理使用这些注解,可以提高应用的性能和响应速度。同时,你也可以根据实际需求扩展和定制Redis的使用方式。希望本文能够帮助你在Spring应用中高效地使用Redis。

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
15天前
|
编解码 NoSQL Java
使用Spring Boot + Redis 队列实现视频文件上传及FFmpeg转码的技术分享
【8月更文挑战第30天】在当前的互联网应用中,视频内容的处理与分发已成为不可或缺的一部分。对于视频平台而言,高效、稳定地处理用户上传的视频文件,并对其进行转码以适应不同设备的播放需求,是提升用户体验的关键。本文将围绕使用Spring Boot结合Redis队列技术来实现视频文件上传及FFmpeg转码的过程,分享一系列技术干货。
53 3
|
20天前
|
Java 开发者 Spring
【SpringBoot 异步魔法】@Async 注解:揭秘 SpringBoot 中异步方法的终极奥秘!
【8月更文挑战第25天】异步编程对于提升软件应用的性能至关重要,尤其是在高并发环境下。Spring Boot 通过 `@Async` 注解简化了异步方法的实现。本文详细介绍了 `@Async` 的基本用法及配置步骤,并提供了示例代码展示如何在 Spring Boot 项目中创建与管理异步任务,包括自定义线程池、使用 `CompletableFuture` 处理结果及异常情况,帮助开发者更好地理解和运用这一关键特性。
93 1
|
16天前
|
缓存 Java 数据库连接
Spring Boot奇迹时刻:@PostConstruct注解如何成为应用初始化的关键先生?
【8月更文挑战第29天】作为一名Java开发工程师,我一直对Spring Boot的便捷性和灵活性着迷。本文将深入探讨@PostConstruct注解在Spring Boot中的应用场景,展示其在资源加载、数据初始化及第三方库初始化等方面的作用。
42 0
|
20天前
|
缓存 NoSQL Java
【Azure Redis 缓存】示例使用 redisson-spring-boot-starter 连接/使用 Azure Redis 服务
【Azure Redis 缓存】示例使用 redisson-spring-boot-starter 连接/使用 Azure Redis 服务
|
1天前
|
Java 数据库连接 数据格式
【Java笔记+踩坑】Spring基础2——IOC,DI注解开发、整合Mybatis,Junit
IOC/DI配置管理DruidDataSource和properties、核心容器的创建、获取bean的方式、spring注解开发、注解开发管理第三方bean、Spring整合Mybatis和Junit
【Java笔记+踩坑】Spring基础2——IOC,DI注解开发、整合Mybatis,Junit
|
27天前
|
NoSQL Java Redis
Redis6入门到实战------ 八、Redis与Spring Boot整合
这篇文章详细介绍了如何在Spring Boot项目中整合Redis,包括在`pom.xml`中添加依赖、配置`application.properties`文件、创建配置类以及编写测试类来验证Redis的连接和基本操作。
Redis6入门到实战------ 八、Redis与Spring Boot整合
|
14天前
|
NoSQL Redis 缓存
Redis 加持下的 Spring 应用性能革命:见证毫秒级响应速度,打造极致用户体验!
【8月更文挑战第31天】Redis 是一个高性能键值存储系统,常用于数据库、缓存及消息中间件。与 Spring 框架集成后,可显著提升应用性能,特别是在高并发场景下。本文通过电子商务网站商品详情页的例子,展示了如何配置 Redis 并使用 `RedisTemplate` 进行数据操作,通过缓存策略优化应用性能,减轻数据库压力。例如,在 `ProductService` 类中,先从 Redis 获取商品信息,若未命中则从数据库获取并缓存至 Redis。此外,还介绍了如何通过 REST 控制器模拟 HTTP 请求进行测试。在实际项目中,结合 Spring Cache 注解可更便捷地管理缓存策略。
29 0
|
16天前
|
缓存 NoSQL Java
惊!Spring Boot遇上Redis,竟开启了一场缓存实战的革命!
【8月更文挑战第29天】在互联网时代,数据的高速读写至关重要。Spring Boot凭借简洁高效的特点广受开发者喜爱,而Redis作为高性能内存数据库,在缓存和消息队列领域表现出色。本文通过电商平台商品推荐系统的实战案例,详细介绍如何在Spring Boot项目中整合Redis,提升系统响应速度和用户体验。
41 0
|
16天前
|
监控 安全 Java
【开发者必备】Spring Boot中自定义注解与处理器的神奇魔力:一键解锁代码新高度!
【8月更文挑战第29天】本文介绍如何在Spring Boot中利用自定义注解与处理器增强应用功能。通过定义如`@CustomProcessor`注解并结合`BeanPostProcessor`实现特定逻辑处理,如业务逻辑封装、配置管理及元数据分析等,从而提升代码整洁度与可维护性。文章详细展示了从注解定义、处理器编写到实际应用的具体步骤,并提供了实战案例,帮助开发者更好地理解和运用这一强大特性,以实现代码的高效组织与优化。
30 0
|
21天前
|
缓存 NoSQL Java
【Azure Redis 缓存】定位Java Spring Boot 使用 Jedis 或 Lettuce 无法连接到 Redis的网络连通性步骤
【Azure Redis 缓存】定位Java Spring Boot 使用 Jedis 或 Lettuce 无法连接到 Redis的网络连通性步骤