微服务——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 在高并发场景下运用的很多。

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

目录
相关文章
|
2月前
|
负载均衡 Java API
《深入理解Spring》Spring Cloud 构建分布式系统的微服务全家桶
Spring Cloud为微服务架构提供一站式解决方案,涵盖服务注册、配置管理、负载均衡、熔断限流等核心功能,助力开发者构建高可用、易扩展的分布式系统,并持续向云原生演进。
|
2月前
|
前端开发 Java 应用服务中间件
《深入理解Spring》 Spring Boot——约定优于配置的革命者
Spring Boot基于“约定优于配置”理念,通过自动配置、起步依赖、嵌入式容器和Actuator四大特性,简化Spring应用的开发与部署,提升效率,降低门槛,成为现代Java开发的事实标准。
|
2月前
|
前端开发 Java 微服务
《深入理解Spring》:Spring、Spring MVC与Spring Boot的深度解析
Spring Framework是Java生态的基石,提供IoC、AOP等核心功能;Spring MVC基于其构建,实现Web层MVC架构;Spring Boot则通过自动配置和内嵌服务器,极大简化了开发与部署。三者层层演进,Spring Boot并非替代,而是对前者的高效封装与增强,适用于微服务与快速开发,而深入理解Spring Framework有助于更好驾驭整体技术栈。
|
2月前
|
XML Java 应用服务中间件
【SpringBoot(一)】Spring的认知、容器功能讲解与自动装配原理的入门,带你熟悉Springboot中基本的注解使用
SpringBoot专栏开篇第一章,讲述认识SpringBoot、Bean容器功能的讲解、自动装配原理的入门,还有其他常用的Springboot注解!如果想要了解SpringBoot,那么就进来看看吧!
461 2
|
2月前
|
监控 Cloud Native Java
Spring Boot 3.x 微服务架构实战指南
🌟蒋星熠Jaxonic,技术宇宙中的星际旅人。深耕Spring Boot 3.x与微服务架构,探索云原生、性能优化与高可用系统设计。以代码为笔,在二进制星河中谱写极客诗篇。关注我,共赴技术星辰大海!(238字)
Spring Boot 3.x 微服务架构实战指南
|
3月前
|
人工智能 Java 机器人
基于Spring AI Alibaba + Spring Boot + Ollama搭建本地AI对话机器人API
Spring AI Alibaba集成Ollama,基于Java构建本地大模型应用,支持流式对话、knife4j接口可视化,实现高隐私、免API密钥的离线AI服务。
3178 2
基于Spring AI Alibaba + Spring Boot + Ollama搭建本地AI对话机器人API
|
3月前
|
监控 安全 Java
Spring Cloud 微服务治理技术详解与实践指南
本文档全面介绍 Spring Cloud 微服务治理框架的核心组件、架构设计和实践应用。作为 Spring 生态系统中构建分布式系统的标准工具箱,Spring Cloud 提供了一套完整的微服务解决方案,涵盖服务发现、配置管理、负载均衡、熔断器等关键功能。本文将深入探讨其核心组件的工作原理、集成方式以及在实际项目中的最佳实践,帮助开发者构建高可用、可扩展的分布式系统。
245 1
存储 JSON Java
569 0
|
3月前
|
数据可视化 Java BI
将 Spring 微服务与 BI 工具集成:最佳实践
本文探讨了 Spring 微服务与商业智能(BI)工具集成的潜力与实践。随着微服务架构和数据分析需求的增长,Spring Boot 和 Spring Cloud 提供了构建可扩展、弹性服务的框架,而 BI 工具则增强了数据可视化与实时分析能力。文章介绍了 Spring 微服务的核心概念、BI 工具在企业中的作用,并深入分析了两者集成带来的优势,如实时数据处理、个性化报告、数据聚合与安全保障。同时,文中还总结了集成过程中的最佳实践,包括事件驱动架构、集中配置管理、数据安全控制、模块化设计与持续优化策略,旨在帮助企业构建高效、智能的数据驱动系统。
240 1
将 Spring 微服务与 BI 工具集成:最佳实践