Redis和Spring Boot:如何协作提高您的应用程序性能

举报
bug菌 发表于 2023/10/11 17:31:26 2023/10/11
【摘要】 🏆本文收录于《Spring Boot从入门到精通》,专门攻坚指数提升,2023 年国内最系统+最强(更新中)。


🏆本文收录于《Spring Boot从入门到精通》,专门攻坚指数提升,2023 年国内最系统+最强(更新中)。

本专栏致力打造最硬核Spring Boot 系列教程,从零基础到进阶系列学习内容,🚀均为全网独家首发,打造精品专栏,专栏持续更新中…欢迎大家订阅持续学习。

环境说明:Windows10 + Idea2021.3.2 + Jdk1.8 + SpringBoot 2.3.1.RELEASE

前言

Redis 是一种高效的非关系型数据库,能够支持复杂的数据结构和操作。在 Spring Boot 应用中,集成 Redis 可以提供更好的性能和扩展性。本文将介绍如何在 Spring Boot 应用中集成 Redis 并使用其基本功能。

摘要

本文将分为以下几个部分:

  1. Redis 集成介绍
  2. Redis 常用操作介绍
  3. Spring Boot 中 Redis 集成实现
  4. Redis 使用方法
  5. 测试用例
  6. 全文小结

Redis 集成介绍

Redis 简介

Redis(Remote Dictionary Server)是一种开源的、高性能的键值对存储数据库。Redis 的出色性能和完善的功能使得它成为最受欢迎的 NoSQL 数据库之一。

Redis 支持多种数据结构,包括字符串、哈希表、列表、集合、有序集合等。Redis 提供了多种操作命令,能够用于对数据结构进行增删改查等操作。

Redis 优点

Redis 具有以下优点:

  • 性能优异:Redis 内置了多种优化机制,能够提供非常高的读写速度。
  • 数据结构丰富:Redis 支持多种数据结构,包括字符串、哈希表、列表、集合、有序集合等。
  • 持久化支持:Redis 支持多种持久化方式,包括 RDB 持久化和 AOF 持久化。
  • 高并发支持:Redis 内置了多种高并发支持机制,能够有效地应对高并发访问。
  • 分布式支持:Redis 支持分布式架构,能够轻松应对大规模数据存储需求。

Redis 常用操作介绍

Redis 提供多种命令,能够对数据进行增删改查等操作。下面介绍 Redis 中常用的命令:

  • SET key value:设置 key 对应的值为 value。
  • GET key:获取 key 对应的值。
  • DEL key:删除 key 对应的值。
  • INCR key:将 key 对应的值加一。
  • DECR key:将 key 对应的值减一。
  • EXISTS key:判断 key 是否存在。
  • KEYS pattern:根据 pattern 获取匹配的 keys。
  • HSET key field value:将 key 对应的哈希表中 field 对应的值设置为 value。
  • HGET key field:获取 key 对应的哈希表中 field 对应的值。
  • HDEL key field:删除 key 对应的哈希表中 field 对应的值。
  • LPUSH key value:将 value 插入到 key 对应的列表的左侧。
  • RPUSH key value:将 value 插入到 key 对应的列表的右侧。
  • LPOP key:弹出并返回 key 对应的列表的左侧元素。
  • RPOP key:弹出并返回 key 对应的列表的右侧元素。
  • SADD key member:将 member 加入到 key 对应的集合中。
  • SMEMBERS key:返回 key 对应的集合中的所有成员。

Spring Boot 中 Redis 集成实现

Spring Boot 已经提供了 Redis 的集成支持,只需要引入相应的依赖后进行配置即可使用 Redis。下面介绍 Redis 在 Spring Boot 中的集成实现。

引入依赖

在 pom.xml 文件中加入以下依赖:

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

配置 Redis

在 application.properties 文件中进行 Redis 配置,例如:

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

使用 RedisTemplate

Spring Boot 提供了 RedisTemplate 用于对 Redis 进行操作。可以通过构造方法或者注入方式进行 RedisTemplate 的创建,并进行相应操作。

我们先来创建一个 RedisTemplate 对象:

@Configuration
public class RedisConfig {

    @Bean
    public RedisTemplate redisTemplate(RedisConnectionFactory redisConnectionFactory) {
        RedisTemplate redisTemplate = new RedisTemplate();
        redisTemplate.setConnectionFactory(redisConnectionFactory);
        redisTemplate.setDefaultSerializer(new StringRedisSerializer());
        return redisTemplate;
    }
}

上述代码中通过 @Bean 注解创建了一个 RedisTemplate 对象,并对其进行了一些基本配置。

Redis 基本操作

下面介绍 Redis 中基本的操作方法:

set 方法

redisTemplate.opsForValue().set("key", "value");

get 方法

String value = (String) redisTemplate.opsForValue().get("key");

判断 key 是否存在

boolean exists = redisTemplate.hasKey("key");

删除 key

redisTemplate.delete("key");

setnx 方法:如果 key 不存在,则设置 key 对应的值为 value

redisTemplate.opsForValue().setIfAbsent("key", "value");

Redis 高级操作

下面介绍 Redis 中的高级操作方法。

list 方法

public void testList() {
    String key = "list";
    // 在列表的左侧插入元素
    redisTemplate.opsForList().leftPush(key, "value1");
    redisTemplate.opsForList().leftPush(key, "value2");
    redisTemplate.opsForList().leftPush(key, "value3");
    
    // 获取指定范围内的列表元素
    List list = redisTemplate.opsForList().range(key, 0, -1);
    System.out.println(list);
    
    // 弹出列表的左侧元素
    String value = (String) redisTemplate.opsForList().leftPop(key);
    System.out.println(value);
    
    // 获取列表长度
    Long size = redisTemplate.opsForList().size(key);
    System.out.println(size);
}

hash 方法

public void testHash() {
    String key = "hash";
    // 设置哈希表中的域值
    redisTemplate.opsForHash().put(key, "field1", "value1");
    redisTemplate.opsForHash().put(key, "field2", "value2");
    redisTemplate.opsForHash().put(key, "field3", "value3");
    
    // 获取所有哈希表中的域值
    Map map = redisTemplate.opsForHash().entries(key);
    System.out.println(map);
    
    // 获取指定哈希表的指定域值
    Object value = redisTemplate.opsForHash().get(key, "field1");
    System.out.println(value);
    
    // 删除哈希表中的一个或多个域值
    redisTemplate.opsForHash().delete(key, "field1", "field2");
}

set 方法

public void testSet() {
    String key = "set";
    // 向集合中添加元素
    redisTemplate.opsForSet().add(key, "value1");
    redisTemplate.opsForSet().add(key, "value2");
    redisTemplate.opsForSet().add(key, "value3");
    
    // 获取集合中的所有元素
    Set set = redisTemplate.opsForSet().members(key);
    System.out.println(set);
    
    // 删除集合中的一个或多个元素
    redisTemplate.opsForSet().remove(key, "value1", "value2");
}

Redis 使用方法

下面介绍如何在 Spring Boot 应用中进行 Redis 使用。

创建 RedisTemplate

可以通过构造方法或者注入方式进行 RedisTemplate 的创建。

@Bean
public RedisTemplate redisTemplate(RedisConnectionFactory redisConnectionFactory) {
    RedisTemplate redisTemplate = new RedisTemplate();
    redisTemplate.setConnectionFactory(redisConnectionFactory);
    redisTemplate.setDefaultSerializer(new StringRedisSerializer());
    return redisTemplate;
}

上述代码中通过 @Bean 注解创建了一个 RedisTemplate 对象,并对其进行了一些基本配置。

Redis 基本操作

下面介绍 Redis 中基本的操作方法。

set 方法

redisTemplate.opsForValue().set("key", "value");

get 方法

String value = (String) redisTemplate.opsForValue().get("key");

判断 key 是否存在

redisTemplate.hasKey(key);

删除key

redisTemplate.delete(key);

刷新缓存时间

redisTemplate.expire(key, time, TimeUnit.SECONDS);

实际运用如下:

在这里插入图片描述

获取key的过期时间

redisTemplate.getExpire(key);

实际运用如下:

在这里插入图片描述

测试用例

为了验证 Redis 的使用效果,我们可以编写相关的测试用例。下面是一个简单的测试用例,用于测试 Redis 中基本方法的使用。

@RunWith(SpringRunner.class)
@SpringBootTest
public class RedisTest {

    @Autowired
    private RedisTemplate redisTemplate;

    @Test
    public void testSetAndGet() {
        redisTemplate.opsForValue().set("testKey", "testValue");
        String value = (String) redisTemplate.opsForValue().get("testKey");
        Assert.assertEquals("testValue", value);
    }

    @Test
    public void testExists() {
        redisTemplate.opsForValue().set("testKey", "testValue");
        boolean exists = redisTemplate.hasKey("testKey");
        Assert.assertTrue(exists);
    }

    @Test
    public void testDelete() {
        redisTemplate.opsForValue().set("testKey", "testValue");
        redisTemplate.delete("testKey");
        boolean exists = redisTemplate.hasKey("testKey");
        Assert.assertFalse(exists);
    }
}

上述测试用例中,我们先通过 set 方法设置了一个键值对,然后使用 get 方法获取值并进行断言。接着使用 hasKey 方法判断该键是否存在,并进行断言。最后使用 delete 方法删除该键值对,并使用 hasKey 方法判断该键是否存在,进行断言。

全文小结

本文介绍了 Redis 的基本概念和常用操作方法,同时介绍了在 Spring Boot 应用中集成 Redis 的实现方法。同时,我们还编写了相关的测试用例,用于验证 Redis 的使用效果。希望本文能够帮助读者了解 Redis 和 Spring Boot 中 Redis 的使用方法。

附录源码

  如上涉及所有源码均已上传同步在「GitHub」,提供给同学们一对一参考学习,辅助你更迅速的掌握。

总结

本文介绍了 Redis 的基本概念和常用操作方法,同时介绍了在 Spring Boot 应用中集成 Redis 的实现方法。Redis 是一种高效的非关系型数据库,支持多种数据结构和操作命令,能够提供非常高的读写速度和多种持久化方式。通过引入相应的依赖和配置,在 Spring Boot 应用中可以轻松集成 Redis 并使用其基本功能。本文还编写了相关的测试用例,用于验证 Redis 的使用效果。读者可以通过本文了解 Redis 和 Spring Boot 中 Redis 的使用方法。

☀️建议/推荐你


无论你是计算机专业的学生,还是对编程有兴趣的小伙伴,都建议直接毫无顾忌的学习此专栏「滚雪球学Spring Boot」,从入门到精通,凡是学习此专栏的同学,均能获取到所需的知识和技能,全网最快速入门SpringBoot,就像滚雪球一样,越滚越大,指数级提升。

  最后,如果这篇文章对你有所帮助,帮忙给作者来个一键三连,关注、点赞、收藏,您的支持就是我坚持写作最大的动力。

  同时欢迎大家关注公众号:「猿圈奇妙屋」 ,以便学习更多同类型的技术文章,免费白嫖最新BAT互联网公司面试题、4000G pdf电子书籍、简历模板、技术文章Markdown文档等海量资料。

📣关于我

我是bug菌,CSDN | 掘金 | InfoQ | 51CTO 等社区博客专家,历届博客之星Top30,掘金年度人气作者Top40,51CTO年度博主Top12,华为云 | 阿里云| 腾讯云等社区优质创作者,全网粉丝合计15w+ ;硬核微信公众号「猿圈奇妙屋」,欢迎你的加入!免费白嫖最新BAT互联网公司面试题、4000G pdf电子书籍、简历模板等海量资料。


【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。