117.info
人生若只如初见

springdata redis缓存怎么用

Spring Data Redis 是一个用于访问 Redis 数据库的框架,它提供了方便的 API 和抽象,使得在 Spring 应用中集成 Redis 变得非常简单。要使用 Spring Data Redis 进行缓存,你需要遵循以下步骤:

  1. 添加依赖

在你的 Spring Boot 项目的 pom.xml 文件中,添加以下依赖:


    org.springframework.boot
    spring-boot-starter-data-redis

  1. 配置 Redis

application.propertiesapplication.yml 文件中,配置 Redis 连接信息:

# application.properties
spring.redis.host=localhost
spring.redis.port=6379

或者

# application.yml
spring:
  redis:
    host: localhost
    port: 6379
  1. 创建 Redis 配置类

创建一个配置类,用于配置 RedisTemplate 和 StringRedisTemplate:

@Configuration
public class RedisConfig {

    @Bean
    public RedisTemplate redisTemplate(RedisConnectionFactory factory) {
        RedisTemplate template = new RedisTemplate<>();
        template.setConnectionFactory(factory);
        template.setKeySerializer(new StringRedisSerializer());
        template.setValueSerializer(new GenericJackson2JsonRedisSerializer());
        template.afterPropertiesSet();
        return template;
    }

    @Bean
    public StringRedisTemplate stringRedisTemplate(RedisConnectionFactory factory) {
        StringRedisTemplate template = new StringRedisTemplate();
        template.setConnectionFactory(factory);
        template.setKeySerializer(new StringRedisSerializer());
        template.setValueSerializer(new StringRedisSerializer());
        template.afterPropertiesSet();
        return template;
    }
}
  1. 使用缓存

在你的服务类中,使用 @Cacheable 注解来标记需要缓存的方法。例如:

@Service
public class UserService {

    @Autowired
    private UserRepository userRepository;

    @Cacheable(value = "https://www.yisu.com/ask/users", key = "#id")
    public User getUserById(Long id) {
        return userRepository.findById(id).orElse(null);
    }

    @CacheEvict(value = "https://www.yisu.com/ask/users", key = "#user.id")
    public User updateUser(User user) {
        userRepository.save(user);
        return user;
    }

    @CacheEvict(value = "https://www.yisu.com/ask/users", allEntries = true)
    public void deleteUser(Long id) {
        userRepository.deleteById(id);
    }
}

在这个例子中,我们使用了三个方法:getUserById、updateUser 和 deleteUser。我们使用 @Cacheable 注解来缓存 getUserById 方法的结果,使用 @CacheEvict 注解来在更新和删除用户时清除缓存。

  1. 启用缓存

在你的 Spring Boot 主类上,添加 @EnableCaching 注解来启用缓存功能:

@SpringBootApplication
@EnableCaching
public class Application {

    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}

现在,你已经成功地在 Spring Boot 项目中集成了 Redis 缓存,并可以使用 @Cacheable@CacheEvict 注解来简化缓存操作。

未经允许不得转载 » 本文链接:https://www.117.info/ask/fec16AzsPAg9Q.html

推荐文章

  • redis如何保证数据一致性

    Redis 保证数据一致性的方法主要有以下几种: 主从复制:Redis 支持主从复制机制,通过将主节点的数据复制到备用的从节点上,保证数据的一致性。当主节点发生故障...

  • redis怎么保证原子性

    Redis使用事务和WATCH命令来保证原子性。事务可以将一系列命令打包成一个单独的操作,要么全部执行成功,要么全部执行失败。在事务中,可以使用MULTI命令开始一个...

  • redis如何配置日志输出目录

    要配置Redis的日志输出目录,可以通过修改Redis配置文件redis.conf来实现。以下是配置Redis日志输出目录的步骤: 打开Redis配置文件redis.conf,通常可以在Redis...

  • redis中info命令的用法是什么

    在Redis中,INFO命令用于获取关于Redis服务器的各种信息和统计数据。通过运行INFO命令,可以获取有关服务器的信息,如服务器版本、运行时间、连接数、内存情况、...

  • springdata redis事务咋管理

    Spring Data Redis 提供了对事务的支持,可以方便地实现事务管理。在 Spring Data Redis 中,事务管理主要通过 RedisTemplate 和 TransactionManager 来实现。下...

  • springdata redis如何操作

    Spring Data Redis 是一个基于 Spring 框架的库,用于简化 Redis 的开发。它提供了许多高级功能,如缓存抽象、事务支持、发布/订阅等。以下是使用 Spring Data R...

  • redis standalone适合啥场景

    Redis Standalone模式,即单机模式,是Redis的默认部署模式,它适用于一些特定的场景,但也有一些局限性。以下是关于Redis Standalone模式适用场景的详细介绍:<...

  • redis standalone有啥限制

    Redis Standalone模式指的是Redis服务器以单机模式运行,没有配置主从复制或集群模式。这种模式有一些限制,主要包括: 存储能力:受限于单台服务器的存储能力,...