6.0Spring Boot 2.0实战 Redis 分布式缓存6.0|学习笔记

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: 快速学习6.0Spring Boot 2.0实战 Redis 分布式缓存6.0。

开发者学堂课程【Spring Boot 2.5.x 开发实战6.0Spring Boot 2.0实战 Redis 分布式缓存6.0】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/853/detail/14071


6.0Spring Boot 2.0实战 Redis 分布式缓存6.0

 

内容介绍:

一、本节内容基础介绍

二、Spring Data Redis6.0

三、Java Spring Data for Redis 架构

四、Linux Install Redis

五、高级面试题

 

一、本节内容基础介绍

本节课讲解 Redis 高并发缓存,在现在的互联网公司中,Redis 的使用非常普遍。新型互联网公司中使用这种开源的缓存,Redis 免费并且其功能特性越来越完善,Redis 无论在基础功能使用(规则丰富的数据类型)还是高级功能使用(集群模式:主从集群、高可用集群、分配集群等等)方面的支持都非常好,而且在扩展知识项(推送、分布式事务等等新特性)。Redis 的生态也非常完善,对 Java 语言或者其他编程语言的体系比较完善。

Spring Boot 为后续 Java 应用开发做铺垫,Spring Cloud 架构属于高阶课程。

 

二、Spring Data Redis6.0

1.介绍

Spring Data 提供了 for Redis一系列接口,本质上 Java 使用Redis 前,安装了基本 Java redis 驱动,并且使用基础的网络连接与 Redis 服务进行交互。本节练习 Redis 单机点模式的使用(为了简单演示体验,一般使用主从、高可用或者侧面集群模式)。

注意:Redis 为最新,可以自己加载一台 Redis 虚拟机去编译和安装,在 Java 中连接远程 Redis 时,Redis 服务器端要允许远程端口连接(生产环境下还要启用安全验证)。

Redis 迭代非常快,功能越来越完善

Java Spring Boot 程序是通过 Java Spring Data for Redis 连接Redis。Redis 的配置、构建等等可以在替换基础的链接池组建可以用 Jedis、Ledis ,但是需要注意,Redis 本身有单点和集群模式,配置文件时需要注意配置文件的修改。Redis 的特性在 Java 语言中使用时要考虑链接库的版本、工具库的版本,需要支持操作。

2.Java Spring Data 2.x for Redis 新特性

(1)支持多种 Redis 驱动程序/连接器的低级抽象(Jedis 和 Lettuce。JRedis 和 SRP 过期)

(2)Spring Data Access exception 和 Redis driver exceptions 转换

(3)RedisTemplate 高级抽象封装 Redis 操作,异常转换和序列化工作

(4)Pubsub 发布订阅模式支持(例如消息驱动 POJO 的MessageListenerContainer)

(5)支持 Redis Sentinel 和 Redis Cluster 集群模式

(6)JDK,String,JSON和Spring Object / XML 映射序列化器

(7)基于 Redis 的 JDK Collection 实现

(8)Atomic counter 原子计数器

(9)Sorting and Pipelining 功能

(10专门 AP 支持 SORT,SORT 7GET 模式和返回批量值数据(11Redis 实现了 Spring 3.1缓存抽象

(12自动实现 Repository 接口,@EnableRedisRepositories支持自定义查找方法

(13支持存储库的 CDl

3.安装步骤

(这里集成的 Spring Boot 是基于最新版本)

(1)Upgrade to Java 8.

(2)Upgrade to Lettuce 5.0.

3Removed support for SRP and JRedis drivers.

(4) Reactive connection support using Lettuce.

5lntroduce Redis feature-specific interfaces forRedisConnection.

(6)Improved RedisConnectionFactory configuration with JedisClientConfiguration and LettuceClientConfiguration.

(7)Revised RedisCache implementation.

(8)Add SPOP with count command for Redis 3.2.

说明:

Redis 本身也在不断迭代,功能越来越完善,Java Spring boot 连接使用 SpringData for Redis,Redis  整个配置构建可以在替换基础的链接池组件,可以用 Jedis 和 Lettuce

Redis本身有单点也有集群模式,配置文件要注意配置参数的修改,整个 Redis 特性在 Java 原理使用中要考虑链接库的版本能支持这些操作。

Java 一定要用 Java8 或者 Jdk1.8 版本,Lettuce 也是5.0以后的版本,后面采用这个默认的集成模式。

过程中还比较有意思,实际  Redis 链接工厂, Factory 是属于工厂模式造链接词链接,每次创建  Redis 链接的时候,可以专门通过工厂类型的来进行创建,然后进行使用,另外可以通过配置给 Redis  客户端工厂添加必要配置。

4.Redis APl

·org.springframework.data.redis.connectio 包

·RedisConnection

·RedisConnectionFactory Interface

基础核心包 org.springframework.data.redis.core,里面包含两个重要类型,一Redis Connection,二Redis Connection Factory Interfac, Redis 链接对象需要指定 Redis 链接工厂,不同的链接池重构了 Redis  的链接工厂,接受的参数大部分一样,如主机、数据库、密码等重要参数都可控,同时也有默认策略,与链接MySQL的链接池相似。

5.RedisConnection 解析

(1)RedisConnection 为 Redis 通信提供核心组件

(2)处理与 Redis 服务器后端的通信。

(3)自动将底层链接异常转换为 Spring DAO 异常

(4)可以在不更改任何代码的情况下切换连接器

(5)操作语义保持不变。

(6)统—接口

(7)工厂模式

(8)仓储模式

 

三、Java Spring Data for Redis 架构

1.介绍

Redis 基础命令最主要的是 get 和set(保持和查询)

Spring 提供了 RedisTemplate 这样一个模板的类型,其封装了 Redis 的基本操作。在之前的课程中,针对 MySQL、MongoDB 也有 Template 的类型,但是 Redis 使用时和其有区别,链接池使用 Jedis 或者 Ledis(一般使用 Jedis 较多)。

image.png

2.RedisTemplate

lnterface

Description

GeoOperations

Redis geospatial操作,例如GEOADD,GEORADIUS....

HashOperations

Redis hash操作

HyperLogLogOperations

Redis HyperLogLog操作,例如PFADD, PFCOUNT...

ListOperations

Redis list操作

SetOperations

Redis set操作

ValueOperations

Redis string (or value)操作

ZSetOperations

Redis zset (or sorted set)操作

 

四、Linux Install Redis

1. Linux 启动 Redis Server

image.png

2.必要条件

(1)Linux

(2)Redis 2.6 or above

(3)Jedis or Lettuce

Redis 提供 Redis Reactive Driver 接口驱动)

3.举例

控制器中存放了新增和查询

查询中调用了 redisRepository 这样的一个类型

image.png

接口中自定义了一些方法(增删改查):

public interface RedisRepository{

Users find( Integer id );

Map<Integer, Users> findA11();

void save(Users user);

void update(Users user);

void delete( Integer id);

}

实现时有一个 RedisTemplate 的类型,用改模板类型对 redisTemplate 操作(基础的增删改查操作)

image.png

下图说明使用的是 Spring data 的Redis

image.png

该处加了 jedis

image.png

可以配置对应的参数,可以从配置文件中读取:

image.png

Bean 构造方法可以指定(传入主机名、端口),主机名和端口这两个参数都可以通过 value 注解的方式从配置文件中自动加载(更简单)。 

image.png

这里是在配置文件中指定给 RedisTemplate 一个 Jedis 连接池的对象,然后就能自己创造链接。

image.png

4. Redis 安装

Redis 安装可以直接使用命令

启动方面是自己编译自己启动(版本如下图)

版本为 6.0.8,并且属于单点模式启动(独立模式启动,只有一个节点,方便调试)

注意:在虚拟机中启动,远程时一定要开启 IP 保护模式的限制的解除,IP 要改。

image.png

如果不用命令行,可以用一个可视化工具(如下图)

image.png

将地址和端口改为正确的并设置名字:

image.png

一定要保证连接成功,否则加入代码会一直出错。

5.测试

要保存100个用户(代码不全)

image.png

调用 redisRepository 做查询操作(代码不全)

image.png

getAll 查询所有:

 image.png

注意:一定要先将 Redis 安装好,然后配置其网络安全模式,客户端才能使用 Redis Desktop Manager0.9.3.817 进行操作

 

五、高级面试题

Redis 安全连接索引机制

GEO 地理位置查询

Spring Data Redis Reactive APl 实现

spring Data Transaction 事务实现

Spring Data Redis  消息推送实现

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
2月前
|
缓存 NoSQL 关系型数据库
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
|
2月前
|
缓存 NoSQL Java
Redis+Caffeine构建高性能二级缓存
大家好,我是摘星。今天为大家带来的是Redis+Caffeine构建高性能二级缓存,废话不多说直接开始~
344 0
|
2月前
|
数据采集 存储 NoSQL
基于Scrapy-Redis的分布式景点数据爬取与热力图生成
基于Scrapy-Redis的分布式景点数据爬取与热力图生成
225 67
|
24天前
|
缓存 NoSQL 算法
高并发秒杀系统实战(Redis+Lua分布式锁防超卖与库存扣减优化)
秒杀系统面临瞬时高并发、资源竞争和数据一致性挑战。传统方案如数据库锁或应用层锁存在性能瓶颈或分布式问题,而基于Redis的分布式锁与Lua脚本原子操作成为高效解决方案。通过Redis的`SETNX`实现分布式锁,结合Lua脚本完成库存扣减,确保操作原子性并大幅提升性能(QPS从120提升至8,200)。此外,分段库存策略、多级限流及服务降级机制进一步优化系统稳定性。最佳实践包括分层防控、黄金扣减法则与容灾设计,强调根据业务特性灵活组合技术手段以应对高并发场景。
366 7
|
2月前
|
消息中间件 缓存 NoSQL
基于Spring Data Redis与RabbitMQ实现字符串缓存和计数功能(数据同步)
总的来说,借助Spring Data Redis和RabbitMQ,我们可以轻松实现字符串缓存和计数的功能。而关键的部分不过是一些"厨房的套路",一旦你掌握了这些套路,那么你就像厨师一样可以准备出一道道饕餮美食了。通过这种方式促进数据处理效率无疑将大大提高我们的生产力。
122 32
|
2月前
|
监控 Java 调度
SpringBoot中@Scheduled和Quartz的区别是什么?分布式定时任务框架选型实战
本文对比分析了SpringBoot中的`@Scheduled`与Quartz定时任务框架。`@Scheduled`轻量易用,适合单机简单场景,但存在多实例重复执行、无持久化等缺陷;Quartz功能强大,支持分布式调度、任务持久化、动态调整和失败重试,适用于复杂企业级需求。文章通过特性对比、代码示例及常见问题解答,帮助开发者理解两者差异,合理选择方案。记住口诀:单机简单用注解,多节点上Quartz;若是任务要可靠,持久化配置不能少。
233 4
|
2月前
|
NoSQL 算法 安全
redis分布式锁在高并发场景下的方案设计与性能提升
本文探讨了Redis分布式锁在主从架构下失效的问题及其解决方案。首先通过CAP理论分析,Redis遵循AP原则,导致锁可能失效。针对此问题,提出两种解决方案:Zookeeper分布式锁(追求CP一致性)和Redlock算法(基于多个Redis实例提升可靠性)。文章还讨论了可能遇到的“坑”,如加从节点引发超卖问题、建议Redis节点数为奇数以及持久化策略对锁的影响。最后,从性能优化角度出发,介绍了减少锁粒度和分段锁的策略,并结合实际场景(如下单重复提交、支付与取消订单冲突)展示了分布式锁的应用方法。
181 3
|
2月前
|
缓存 监控 NoSQL
Redis设计与实现——分布式Redis
Redis Sentinel 和 Cluster 是 Redis 高可用与分布式架构的核心组件。Sentinel 提供主从故障检测与自动切换,通过主观/客观下线判断及 Raft 算法选举领导者完成故障转移,但存在数据一致性和复杂度问题。Cluster 支持数据分片和水平扩展,基于哈希槽分配数据,具备自动故障转移和节点发现机制,适合大规模高并发场景。复制机制包括全量同步和部分同步,通过复制积压缓冲区优化同步效率,但仍面临延迟和资源消耗挑战。两者各有优劣,需根据业务需求选择合适方案。
|
2月前
|
存储 NoSQL Java
从扣减库存场景来讲讲redis分布式锁中的那些“坑”
本文从一个简单的库存扣减场景出发,深入分析了高并发下的超卖问题,并逐步优化解决方案。首先通过本地锁解决单机并发问题,但集群环境下失效;接着引入Redis分布式锁,利用SETNX命令实现加锁,但仍存在死锁、锁过期等隐患。文章详细探讨了通过设置唯一标识、续命机制等方法完善锁的可靠性,并最终引出Redisson工具,其内置的锁续命和原子性操作极大简化了分布式锁的实现。最后,作者剖析了Redisson源码,揭示其实现原理,并预告后续关于主从架构下分布式锁的应用与性能优化内容。
117 0
|
4月前
|
前端开发 Java 数据库
微服务——SpringBoot使用归纳——Spring Boot集成Thymeleaf模板引擎——Thymeleaf 介绍
本课介绍Spring Boot集成Thymeleaf模板引擎。Thymeleaf是一款现代服务器端Java模板引擎,支持Web和独立环境,可实现自然模板开发,便于团队协作。与传统JSP不同,Thymeleaf模板可以直接在浏览器中打开,方便前端人员查看静态原型。通过在HTML标签中添加扩展属性(如`th:text`),Thymeleaf能够在服务运行时动态替换内容,展示数据库中的数据,同时兼容静态页面展示,为开发带来灵活性和便利性。
121 0

热门文章

最新文章