微服务——SpringBoot使用归纳——Spring Boot 中集成Redis——Spring Boot 集成 Redis

简介: 本文介绍了在Spring Boot中集成Redis的方法,包括依赖导入、Redis配置及常用API的使用。通过导入`spring-boot-starter-data-redis`依赖和配置`application.yml`文件,可轻松实现Redis集成。文中详细讲解了StringRedisTemplate的使用,适用于字符串操作,并结合FastJSON将实体类转换为JSON存储。还展示了Redis的string、hash和list类型的操作示例。最后总结了Redis在缓存和高并发场景中的应用价值,并提供课程源代码下载链接。

3. Spring Boot 集成 Redis

3.1 依赖导入

Spring Boot 集成 redis 很方便,只需要导入一个 redis 的 starter 依赖即可。如下:

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-data-redis</artifactId>

</dependency>

<!--阿里巴巴fastjson -->

<dependency>

   <groupId>com.alibaba</groupId>

   <artifactId>fastjson</artifactId>

   <version>1.2.35</version>

</dependency>

这里也导入阿里巴巴的 fastjson 是为了在后面我们要存一个实体,为了方便把实体转换成 json 字符串存进去。

3.2 Redis 配置

导入了依赖之后,我们在 application.yml 文件里配置 redis:

server:

 port: 8080

spring:

 #redis相关配置

 redis:

   database: 5

   # 配置redis的主机地址,需要修改成自己的

   host: 192.168.48.190

   port: 6379

   password: 123456

   timeout: 5000

   jedis:

     pool:

       # 连接池中的最大空闲连接,默认值也是8。

       max-idle: 500

       # 连接池中的最小空闲连接,默认值也是0。

       min-idle: 50

       # 如果赋值为-1,则表示不限制;如果pool已经分配了maxActive个jedis实例,则此时pool的状态为exhausted(耗尽)

       max-active: 1000

       # 等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时。如果超过等待时间,则直接抛出JedisConnectionException

       max-wait: 2000

3.3 常用 api 介绍

Spring Boot 对 redis 的支持已经非常完善了,丰富的 api 已经足够我们日常的开发,这里我介绍几个最常用的供大家学习,其他 api 希望大家自己多学习,多研究。用到会去查即可。

有两个 redis 模板:RedisTemplate 和 StringRedisTemplate。我们不使用 RedisTemplate,RedisTemplate 提供给我们操作对象,操作对象的时候,我们通常是以 json 格式存储,但在存储的时候,会使用 Redis 默认的内部序列化器;导致我们存进里面的是乱码之类的东西。当然了,我们可以自己定义序列化,但是比较麻烦,所以使用 StringRedisTemplate 模板。StringRedisTemplate 主要给我们提供字符串操作,我们可以将实体类等转成 json 字符串即可,在取出来后,也可以转成相应的对象,这就是上面我导入了阿里 fastjson 的原因。

3.3.1 redis:string 类型

新建一个 RedisService,注入 StringRedisTemplate,使用 stringRedisTemplate.opsForValue() 可以获取 ValueOperations<String, String> 对象,通过该对象即可读写 redis 数据库了。如下:

public class RedisService {


   @Resource

   private StringRedisTemplate stringRedisTemplate;


   /**

    * set redis: string类型

    * @param key key

    * @param value value

    */

   public void setString(String key, String value){

       ValueOperations<String, String> valueOperations = stringRedisTemplate.opsForValue();

       valueOperations.set(key, value);

   }


   /**

    * get redis: string类型

    * @param key key

    * @return

    */

   public String getString(String key){

       return stringRedisTemplate.opsForValue().get(key);

   }

该对象操作的是 string,我们也可以存实体类,只需要将实体类转换成 json 字符串即可。下面来测试一下:

@RunWith(SpringRunner.class)

@SpringBootTest

public class Course14ApplicationTests {


   private static final Logger logger = LoggerFactory.getLogger(Course14ApplicationTests.class);


@Resource

private RedisService redisService;


@Test

public void contextLoads() {

       //测试redis的string类型

       redisService.setString("weichat","程序员私房菜");

       logger.info("我的微信公众号为:{}", redisService.getString("weichat"));


       // 如果是个实体,我们可以使用json工具转成json字符串,

       User user = new User("CSDN", "123456");

       redisService.setString("userInfo", JSON.toJSONString(user));

       logger.info("用户信息:{}", redisService.getString("userInfo"));

   }

}

先启动 redis,然后运行这个测试用例,观察控制台打印的日志如下:

我的微信公众号为:程序员私房菜

用户信息:{"password":"123456","username":"CSDN"}

3.3.2 redis:hash 类型

hash 类型其实原理和 string 一样的,但是有两个 key,使用 stringRedisTemplate.opsForHash() 可以获取 HashOperations<String, Object, Object> 对象。比如我们要存储订单信息,所有订单信息都放在 order 下,针对不同用户的订单实体,可以通过用户的 id 来区分,这就相当于两个 key 了。

@Service

public class RedisService {


   @Resource

   private StringRedisTemplate stringRedisTemplate;


   /**

    * set redis: hash类型

    * @param key key

    * @param filedKey filedkey

    * @param value value

    */

   public void setHash(String key, String filedKey, String value){

       HashOperations<String, Object, Object> hashOperations = stringRedisTemplate.opsForHash();

       hashOperations.put(key,filedKey, value);

   }


   /**

    * get redis: hash类型

    * @param key key

    * @param filedkey filedkey

    * @return

    */

   public String getHash(String key, String filedkey){

       return (String) stringRedisTemplate.opsForHash().get(key, filedkey);

   }

}

可以看出,hash 和 string 没啥两样,只不过多了个参数,Spring Boot 中操作 redis 非常简单方便。来测试一下:

@SpringBootTest

public class Course14ApplicationTests {


   private static final Logger logger = LoggerFactory.getLogger(Course14ApplicationTests.class);


@Resource

private RedisService redisService;


@Test

public void contextLoads() {

       //测试redis的hash类型

       redisService.setHash("user", "name", JSON.toJSONString(user));

       logger.info("用户姓名:{}", redisService.getHash("user","name"));

   }

}

3.3.3 redis:list 类型

使用 stringRedisTemplate.opsForList() 可以获取 ListOperations<String, String> listOperations  redis 列表对象,该列表是个简单的字符串列表,可以支持从左侧添加,也可以支持从右侧添加,一个列表最多包含 2 ^ 32 -1 个元素。

@Service

public class RedisService {


   @Resource

   private StringRedisTemplate stringRedisTemplate;


   /**

    * set redis:list类型

    * @param key key

    * @param value value

    * @return

    */

   public long setList(String key, String value){

       ListOperations<String, String> listOperations = stringRedisTemplate.opsForList();

       return listOperations.leftPush(key, value);

   }


   /**

    * get redis:list类型

    * @param key key

    * @param start start

    * @param end end

    * @return

    */

   public List<String> getList(String key, long start, long end){

       return stringRedisTemplate.opsForList().range(key, start, end);

   }

}

可以看出,这些 api 都是一样的形式,方便记忆也方便使用。具体的 api 细节我就不展开了,大家可以自己看 api 文档。其实,这些 api 根据参数和返回值也能知道它们是做什么用的。来测试一下:

@RunWith(SpringRunner.class)

@SpringBootTest

public class Course14ApplicationTests {


   private static final Logger logger = LoggerFactory.getLogger(Course14ApplicationTests.class);


@Resource

private RedisService redisService;


@Test

public void contextLoads() {

       //测试redis的list类型

       redisService.setList("list", "football");

       redisService.setList("list", "basketball");

       List<String> valList = redisService.getList("list",0,-1);

       for(String value :valList){

           logger.info("list中有:{}", value);

       }

   }

}

4. 总结

本节主要介绍了 redis 的使用场景、安装过程,以及 Spring Boot 中集成 redis 的详细步骤。在实际项目中,通常都用 redis 作为缓存,在查询数据库的时候,会先从 redis 中查找,如果有信息,则从 redis 中取;如果没有,则从数据库中查,并且同步到 redis 中,下次 redis 中就有了。更新和删除也是如此,都需要同步到 redis。redis 在高并发场景下运用的很多。

课程源代码下载地址:戳我下载

目录
相关文章
|
5月前
|
NoSQL Java 网络安全
SpringBoot启动时连接Redis报错:ERR This instance has cluster support disabled - 如何解决?
通过以上步骤一般可以解决由于配置不匹配造成的连接错误。在调试问题时,一定要确保服务端和客户端的Redis配置保持同步一致。这能够确保SpringBoot应用顺利连接到正确配置的Redis服务,无论是单机模式还是集群模式。
511 5
|
5月前
|
前端开发 Java 应用服务中间件
《深入理解Spring》 Spring Boot——约定优于配置的革命者
Spring Boot基于“约定优于配置”理念,通过自动配置、起步依赖、嵌入式容器和Actuator四大特性,简化Spring应用的开发与部署,提升效率,降低门槛,成为现代Java开发的事实标准。
|
5月前
|
前端开发 Java 微服务
《深入理解Spring》:Spring、Spring MVC与Spring Boot的深度解析
Spring Framework是Java生态的基石,提供IoC、AOP等核心功能;Spring MVC基于其构建,实现Web层MVC架构;Spring Boot则通过自动配置和内嵌服务器,极大简化了开发与部署。三者层层演进,Spring Boot并非替代,而是对前者的高效封装与增强,适用于微服务与快速开发,而深入理解Spring Framework有助于更好驾驭整体技术栈。
|
5月前
|
XML Java 应用服务中间件
【SpringBoot(一)】Spring的认知、容器功能讲解与自动装配原理的入门,带你熟悉Springboot中基本的注解使用
SpringBoot专栏开篇第一章,讲述认识SpringBoot、Bean容器功能的讲解、自动装配原理的入门,还有其他常用的Springboot注解!如果想要了解SpringBoot,那么就进来看看吧!
636 2
|
6月前
|
人工智能 Java 机器人
基于Spring AI Alibaba + Spring Boot + Ollama搭建本地AI对话机器人API
Spring AI Alibaba集成Ollama,基于Java构建本地大模型应用,支持流式对话、knife4j接口可视化,实现高隐私、免API密钥的离线AI服务。
5509 2
基于Spring AI Alibaba + Spring Boot + Ollama搭建本地AI对话机器人API
存储 JSON Java
768 0
|
6月前
|
NoSQL Java 调度
分布式锁与分布式锁使用 Redis 和 Spring Boot 进行调度锁(不带 ShedLock)
分布式锁是分布式系统中用于同步多节点访问共享资源的机制,防止并发操作带来的冲突。本文介绍了基于Spring Boot和Redis实现分布式锁的技术方案,涵盖锁的获取与释放、Redis配置、服务调度及多实例运行等内容,通过Docker Compose搭建环境,验证了锁的有效性与互斥特性。
550 0
分布式锁与分布式锁使用 Redis 和 Spring Boot 进行调度锁(不带 ShedLock)
|
6月前
|
人工智能 Java 开发者
【Spring】原理解析:Spring Boot 自动配置
Spring Boot通过“约定优于配置”的设计理念,自动检测项目依赖并根据这些依赖自动装配相应的Bean,从而解放开发者从繁琐的配置工作中解脱出来,专注于业务逻辑实现。
2255 0
|
9月前
|
机器学习/深度学习 数据采集 人机交互
springboot+redis互联网医院智能导诊系统源码,基于医疗大模型、知识图谱、人机交互方式实现
智能导诊系统基于医疗大模型、知识图谱与人机交互技术,解决患者“知症不知病”“挂错号”等问题。通过多模态交互(语音、文字、图片等)收集病情信息,结合医学知识图谱和深度推理,实现精准的科室推荐和分级诊疗引导。系统支持基于规则模板和数据模型两种开发原理:前者依赖人工设定症状-科室规则,后者通过机器学习或深度学习分析问诊数据。其特点包括快速病情收集、智能病症关联推理、最佳就医推荐、分级导流以及与院内平台联动,提升患者就诊效率和服务体验。技术架构采用 SpringBoot+Redis+MyBatis Plus+MySQL+RocketMQ,确保高效稳定运行。
670 0