当前位置: 首页 > news >正文

Spring Boot整合Redis的高效数据缓存实践

引言

在现代Web应用开发中,数据缓存是提高系统性能和响应速度的关键。Redis作为一种高性能的缓存和数据存储解决方案,被广泛应用于各种场景。本文将研究如何使用Spring Boot整合Redis,通过这个强大的缓存工具提高应用的性能和可伸缩性。

整合redis,需要先安装redis

Redis 

Redis是一款key-value存储结构的内存级NoSQL数据库

  • 支持多种数据存储格式
  • 支持持久化
  • 支持集群

五种数据类型:

  • String(字符串)
  • Hash(哈希)
  • List(列表)
  • Set(集合)
  • zSet(有序集合)

好处

  • 缓存加速:Redis是一个高性能的内存数据库,使用它可以将常用的数据缓存在内存中,从而提高系统的读取速度。例如,将数据库查询结果或计算结果缓存到Redis中,下次需要时可以直接从Redis获取,减少对数据库或计算资源的访问。
  • 分布式会话管理:在分布式系统中,多个服务实例可能需要共享用户的会话信息。Rdis提供了高效的键值存储和过期时间设置,可以用于实现分布式会话管理。通过将用户的会话数据存储在Redis中,各个服务实例可以无状态地处理请求,提高系统的可扩展性和容错性。 
  • 队列和消息发布订阅:Redis的发布订阅功能可以用于解耦系统的组件或模块之间的通信。你可以使用Redis的队列功能实现异步任务处理、消息队列等场景。同时,Redis还提供了强大的消息发布订阅机制,可以用于实时推送消息给订阅者。
  • 计数器和排行榜:Redis支持原子操作和高并发的特性,非常适合用于实现计数器和排行榜功能。例如,你可以使用Redis的原子操作实现文章或视频的点赞、收富等计数功能,也可以使用有序集合实现排行榜。
  • 地理位置和地理搜索:Reds提供了地理位置的存储和查询功能,可以将经纬度坐标存储在Redis中,并支持以半径为条件进行搜索。这在实现地理位置相关的应用如附近的人、附近的商家等方面非常有用。
  • 分布式锁和限流:Redis的分布式锁功能可以用于解决分布式系统中的并发访问问题,保证共享资源的正确性。此外,Redis还可以用于实现请求限流,控制系统的访问频率,防止恶意请求或系统过载。

Redis下载( Windows版)

https://github.com/tporadowski/redis/releases

Redis安装与启动( Windows版)

服务端启动命令

redis-server.exe redis.windows.conf

客户端启动命令

redis-cli.exe

步骤一:引入Redis依赖

首先,在Spring Boot项目的pom.xml文件中引入Redis的相关依赖:

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

步骤二:配置Redis连接信息

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

# Redis配置
spring.redis.host=localhost
spring.redis.port=6379
spring.redis.password=your-password  # 如果有密码的话
spring.redis.database=0

RedisTemplate相关方法

方法说明
redisTemplate.opsForValue()操作String
redisTemplate.opsForHash()操作hash
redisTemplate.opsForList()操作List
redisTemplate.opsForSet()操作set
redisTemplate.opsForZSet()操作有序set

步骤三:使用RedisTemplate进行数据操作

@SpringBootTest
public class RedisApplicationTests {@Autowiredprivate RedisTemplate redisTemplate;@Testvoid set() {ValueOperations ops = redisTemplate.opsForValue();ops.set("name","奇遇少年");}
}

问题出现了:当我们使用Redis客户端查看刚刚存入Redis数据库的数据时,结果是这样的:

bbdc6760a76e4d3686f3d8fdc9938f8e.png

这是因为在使用默认的对象RedisTemplate时,会把value值序列化为byte类型,所以就出现了上图的结果。

解决方案:

使用StringRedisTemplate

@SpringBootTest(classes = RedisApplication.class)
public class RedisApplicationTests {@Autowiredprivate StringRedisTemplate stringRedisTemplate;@Testvoid set() {ValueOperations<String, String> ops = stringRedisTemplate.opsForValue();ops.set("name","奇遇少年");}}

自定义序列化方式

@Configuration
public class RedisConfig {@Beanpublic RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory connectionFactory) {RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();redisTemplate.setKeySerializer(stringRedisSerializer);redisTemplate.setHashKeySerializer(stringRedisSerializer);redisTemplate.setValueSerializer(new Jackson2JsonRedisSerializer<Object>(Object.class));redisTemplate.setHashValueSerializer(new GenericJackson2JsonRedisSerializer());redisTemplate.setConnectionFactory(connectionFactory);return redisTemplate;}
}

4023ab36142f49f0836367cc6ad56b76.png
redis客户端选择

springboot整合redis技术提供了多种客户端兼容模式,默认提供的是lettucs客户端技术,也可以根据需要切换成指定客户端技术,例如jedis客户端技术,切换成jedis客户端技术操作步骤如下:

步骤一:引入Redis依赖

<dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId>
</dependency>

jedis坐标受springboot管理,无需提供版本号

步骤二:配置客户端技术类型,设置为jedis

spring:redis:host: localhostport: 6379client-type: jedis

步骤二:根据需要设置对应的配置

spring:redis:host: localhostport: 6379client-type: jedislettuce:pool:max-active: 16jedis:pool:max-active: 16

lettcus与jedis区别

  • jedis连接Redis服务器是直连模式,当多线程模式下使用jedis会存在线程安全问题,解决方案可以通过配置连接池使每个连接专用,这样整体性能就大受影响
  • lettcus基于Netty框架进行与Redis服务器连接,底层设计中采用StatefulRedisConnection。 StatefulRedisConnection自身是线程安全的,可以保障并发访问安全问题,所以一个连接可以被多线程复用。当然lettcus也支持多连接实例一起工作

结语

通过本文的指南,你学到了如何使用Spring Boot整合Redis,从而提高应用的性能和可伸缩性。Redis作为一种高性能的缓存和数据存储解决方案,为应用提供了快速、可靠的数据缓存能力。通过合理配置和使用Redis,你能够优化数据访问,提高系统的响应速度,为用户提供更好的体验。希望这篇博文能够帮助你顺利整合Redis到你的Spring Boot项目中。
 

 

 

相关文章:

  • 《30天自制操作系统》 第一周(D1-D7) 笔记
  • GraphicsMagick 的 OpenCL 开发记录(二十五)
  • Vue2 - keep-alive 作用和原理
  • Sql server强制走索引
  • 【工具变量】中国各省市级是否属于“知识产权示范区”匹配数据(2010-2024年)
  • 强化学习 - Trust Region Policy Optimization (TRPO)
  • 2、互信息(Mutual Information)
  • CSS探索浏览器兼容性
  • 【C++干货铺】C++中的IO流和文件操作
  • Java基础知识-异常
  • Delphi 7 IdHTTP POST 中文乱码得解决
  • k8s实例
  • 【Linux 基础】常用基础指令(上)
  • Impala依赖组件的客户端源码下载
  • 3d gaussian splatting笔记(paper部分翻译)
  • 【399天】跃迁之路——程序员高效学习方法论探索系列(实验阶段156-2018.03.11)...
  • 【个人向】《HTTP图解》阅后小结
  • 2019年如何成为全栈工程师?
  • - C#编程大幅提高OUTLOOK的邮件搜索能力!
  • django开发-定时任务的使用
  • eclipse的离线汉化
  • Laravel Mix运行时关于es2015报错解决方案
  • Linux下的乱码问题
  • Linux学习笔记6-使用fdisk进行磁盘管理
  • PAT A1050
  • vagrant 添加本地 box 安装 laravel homestead
  • vue脚手架vue-cli
  • Vue源码解析(二)Vue的双向绑定讲解及实现
  • 阿里研究院入选中国企业智库系统影响力榜
  • 大快搜索数据爬虫技术实例安装教学篇
  • 对象管理器(defineProperty)学习笔记
  • 更好理解的面向对象的Javascript 1 —— 动态类型和多态
  • 关于Flux,Vuex,Redux的思考
  • 记一次删除Git记录中的大文件的过程
  • 跳前端坑前,先看看这个!!
  • 一道闭包题引发的思考
  • 以太坊客户端Geth命令参数详解
  • 在electron中实现跨域请求,无需更改服务器端设置
  • 没有任何编程基础可以直接学习python语言吗?学会后能够做什么? ...
  • !$boo在php中什么意思,php前戏
  • # 飞书APP集成平台-数字化落地
  • #Java第九次作业--输入输出流和文件操作
  • (1)(1.8) MSP(MultiWii 串行协议)(4.1 版)
  • (1)bark-ml
  • (9)目标检测_SSD的原理
  • (C语言)输入一个序列,判断是否为奇偶交叉数
  • (poj1.2.1)1970(筛选法模拟)
  • (二)JAVA使用POI操作excel
  • (二)pulsar安装在独立的docker中,python测试
  • (算法)Game
  • (详细版)Vary: Scaling up the Vision Vocabulary for Large Vision-Language Models
  • (循环依赖问题)学习spring的第九天
  • (转)视频码率,帧率和分辨率的联系与区别
  • .h头文件 .lib动态链接库文件 .dll 动态链接库
  • .net mvc 获取url中controller和action