Spring Boot 中的 Redis 的数据操作配置和使用

这篇具有很好参考价值的文章主要介绍了Spring Boot 中的 Redis 的数据操作配置和使用。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Spring Boot 中的 Redis 的数据操作配置和使用

Redis 是一种高性能的 NoSQL 数据库,它支持多种数据结构,包括字符串、哈希、列表、集合和有序集合。Redis 还提供了丰富的命令,可以对数据进行快速的 CRUD 操作。Spring Boot 是一个基于 Spring 的快速开发框架,它提供了对 Redis 的集成支持。在本文中,我们将介绍如何在 Spring Boot 应用程序中配置和使用 Redis 的数据操作。

Spring Boot 中的 Redis 的数据操作配置和使用

Redis 简介

Redis 是一款开源的高性能键值存储系统,它支持多种数据结构,包括字符串、哈希、列表、集合和有序集合。Redis 的优势在于其快速的读写速度和高效的内存管理,使其成为一个非常适合缓存和数据存储的工具。Redis 还提供了事务处理、发布订阅、Lua 脚本等丰富的功能,使其成为一个非常灵活的数据库。

Spring Boot 中的 Redis 数据操作

Spring Boot 提供了对 Redis 的支持,可以通过 Spring Data Redis 来进行数据操作。Spring Data Redis 是一个基于 Spring Data 的模块,提供了对 Redis 的集成支持。它可以通过注解或者 XML 文件来配置 Redis 的数据访问。

配置 Redis 连接池

在 Spring Boot 应用程序中使用 Redis,首先需要配置 Redis 的连接池。可以使用 Spring Boot 自带的 Lettuce 连接池,也可以使用 Jedis 连接池。这里我们选择使用 Lettuce 连接池。

@Configuration
public class RedisConfig {

    @Value("${spring.redis.host}")
    private String host;

    @Value("${spring.redis.port}")
    private int port;

    @Value("${spring.redis.password}")
    private String password;

    @Value("${spring.redis.timeout}")
    private int timeout;

    @Bean
    public LettuceConnectionFactory lettuceConnectionFactory() {
        RedisStandaloneConfiguration redisConfiguration = new RedisStandaloneConfiguration(host, port);
        redisConfiguration.setPassword(RedisPassword.of(password));
        return new LettuceConnectionFactory(redisConfiguration);
    }

    @Bean
    public RedisTemplate<String, Object> redisTemplate() {
        RedisTemplate<String, Object> template = new RedisTemplate<>();
        template.setConnectionFactory(lettuceConnectionFactory());
        template.setDefaultSerializer(new Jackson2JsonRedisSerializer<>(Object.class));
        return template;
    }
}

在上面的代码中,我们定义了一个 RedisConfig 类,通过 @Value 注解读取配置文件中的 Redis 主机、端口、密码和超时时间。然后通过 LettuceConnectionFactory 创建 Redis 连接工厂,并将其注入到 Spring 容器中。在 RedisTemplate 中,我们定义了默认的序列化器为 Jackson2JsonRedisSerializer,这样我们就可以直接将 Java 对象序列化为 JSON 存储到 Redis 中。

数据操作示例

在 Spring Boot 应用程序中使用 Redis,可以通过 RedisTemplate 进行数据操作。下面是一个数据操作的示例代码。

@Service
public class UserService {

    private static final String KEY_USER = "user";

    @Autowired
    private RedisTemplate<String, Object> redisTemplate;

    public void save(User user) {
        redisTemplate.opsForHash().put(KEY_USER, user.getId(), user);
    }

    public void delete(String id) {
        redisTemplate.opsForHash().delete(KEY_USER, id);
    }

    public User findById(String id) {
        return (User) redisTemplate.opsForHash().get(KEY_USER, id);
    }

    public List<User> findAll() {
        return redisTemplate.opsForHash().values(KEY_USER).stream()
                .map(obj -> (User) obj)
                .collect(Collectors.toList());
    }
}

在上面的代码中,我们定义了一个 UserService 类,使用 @Autowired 注解注入了 RedisTemplate。在该类中,我们定义了一些数据操作方法,如 save、delete、findById 和 findAll 等。这些方法直接调用 RedisTemplate 中封装的基本数据操作方法。

使用 Redis 注解

除了使用 RedisTemplate 进行数据操作外,Spring Data Redis 还提供了一些注解来简化数据操作。这些注解包括@Cacheable、@CachePut、@CacheEvict 和 @RedisHash 等。下面是一个使用 @Cacheable 注解的示例代码。

@Service
public class UserService {

    @Autowired
    private UserRepository userRepository;

    @Cacheable(value = "user", key = "#id")
    public User findById(String id) {
        return userRepository.findById(id).orElse(null);
    }
}

在上面的代码中,我们使用了 @Cacheable 注解来缓存 findById 方法的结果。这样,当下次调用 findById 方法时,如果传入的 id 值和之前查询的 id 值相同,则直接从缓存中获取结果,不需要再次执行数据库查询操作。

总结

本文介绍了在 Spring Boot 应用程序中配置和使用 Redis 的数据操作。首先,我们使用 Lettuce 连接池配置了 Redis 的连接。然后,我们使用 RedisTemplate 进行了基本的数据操作,包括 put、get、delete 和 values 等。最后,我们介绍了使用 @Cacheable 注解来简化数据操作的方法。通过本文的介绍,读者可以快速上手使用 Redis 进行数据存储和缓存。文章来源地址https://www.toymoban.com/news/detail-514136.html

到了这里,关于Spring Boot 中的 Redis 的数据操作配置和使用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【Spring Boot 3】【Redis】基本数据类型操作

    软件开发是一门实践性科学,对大多数人来说,学习一种新技术不是一开始就去深究其原理,而是先从做出一个可工作的DEMO入手。但在我个人学习和工作经历中,每次学习新技术总是要花费或多或少的时间、检索不止一篇资料才能得出一个可工作的DEMO,这占用了我大量的时

    2024年01月20日
    浏览(40)
  • 使用Spring Boot操作Redis、ES、MongoDB举例

    在Spring Boot应用程序中操作Redis通常涉及到使用Spring Data Redis,这是一个提供简便方法来操作Redis的库。以下是一个基本示例,演示如何在Spring Boot应用程序中集成和使用Redis: 步骤 1: 添加依赖项 首先,在你的 pom.xml 文件中添加Spring Data Redis的依赖项。 步骤 2: 配置Redis 在你的

    2024年01月25日
    浏览(39)
  • 在Spring Boot微服务使用RedisTemplate操作Redis集群

    记录 :442 场景 :在Spring Boot微服务使用RedisTemplate操作Redis集群的缓存和队列等数据类型。 版本 :JDK 1.8,Spring Boot 2.6.3,redis-6.2.5。 1.微服务中 配置Redis信息 1.1在pom.xml添加依赖 pom.xml文件: 解析:spring-boot-starter-data-redis和spring-boot版本保持一致。 1.2在application.yml中配置Redis集群

    2024年02月12日
    浏览(36)
  • Spring Boot 整合 Redis 全面教程:从配置到使用

    Redis 是一种高性能的键值存储数据库,而 Spring Boot 是一个简化了开发过程的 Java 框架。将两者结合,可以轻松地在 Spring Boot 项目中使用 Redis 来实现数据缓存、会话管理和分布式锁等功能。 在 pom.xml 文件中添加 Redis 相关依赖 在 application.properties 或 application.yml 配置文件中添

    2024年02月13日
    浏览(39)
  • 在Spring Boot微服务使用ListOperations操作Redis集群List列表

    记录 :444 场景 :在Spring Boot微服务使用RedisTemplate的ListOperations操作Redis集群的List列表数据类型。 版本 :JDK 1.8,Spring Boot 2.6.3,redis-6.2.5。 1.微服务中 配置Redis信息 1.1在pom.xml添加依赖 pom.xml文件: 解析:spring-boot-starter-data-redis和spring-boot版本保持一致。 1.2在application.yml中配置

    2024年02月08日
    浏览(48)
  • 在Spring Boot微服务使用ZSetOperations操作Redis集群Zset(有序集合)

    记录 :447 场景 :在Spring Boot微服务使用RedisTemplate的ZSetOperations操作Redis集群的Zset(有序集合)数据类型。 版本 :JDK 1.8,Spring Boot 2.6.3,redis-6.2.5。 1.微服务中 配置Redis信息 1.1在pom.xml添加依赖 pom.xml文件: 解析:spring-boot-starter-data-redis和spring-boot版本保持一致。 1.2在application.ym

    2024年02月08日
    浏览(43)
  • 在Spring Boot微服务使用JedisCluster操作Redis集群String字符串

    记录 :449 场景 :在Spring Boot微服务使用JedisCluster操作Redis集群的String字符串数据类型。 版本 :JDK 1.8,Spring Boot 2.6.3,redis-6.2.5,jedis-3.7.1。 1.微服务中 配置Redis信息 1.1在pom.xml添加依赖 pom.xml文件: 解析:在Spring Boot中默认集成jedis,使用无需加版本号,本例版本3.7.1是Spring Bo

    2024年02月08日
    浏览(54)
  • Spring Boot中的Elasticsearch自动配置:原理与使用

    在Spring Boot中,Elasticsearch是非常流行的搜索引擎。为了方便开发人员使用Elasticsearch,Spring Boot提供了Elasticsearch自动配置功能。本文将介绍Elasticsearch自动配置的原理与使用。 Elasticsearch自动配置是Spring Boot对Elasticsearch进行封装的一种方式,它主要是通过将Elasticsearch相关的配置

    2024年02月12日
    浏览(51)
  • Spring boot 操作 Redis

    🌹作者主页:青花锁 🌹简介:Java领域优质创作者🏆、Java微服务架构公号作者😄 🌹简历模板、学习资料、面试题库、技术互助 🌹文末获取联系方式 📝 专栏 描述 Java项目实战 介绍Java组件安装、使用;手写框架等 Aws服务器实战 Aws Linux服务器上操作nginx、git、JDK、Vue Jav

    2024年03月20日
    浏览(49)
  • Spring Boot 中的 RabbitMQ 的消息接收配置是什么,原理,如何使用

    RabbitMQ 是一个流行的消息队列系统,它可以用于在应用程序之间传递消息。Spring Boot 提供了对 RabbitMQ 的支持,我们可以使用 Spring Boot 中的 RabbitMQ 消息接收配置来接收 RabbitMQ 中的消息。本文将介绍 RabbitMQ 的消息接收配置的原理和如何在 Spring Boot 中使用它。 在 RabbitMQ 中,消

    2024年02月13日
    浏览(47)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包