开发者学堂课程干货总结——Spring Boot 2.5.x开发实战(六)

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: Spring Boot 2.5.x开发实战课时6——Spring Boot 2.5实战Redis分布式缓存6.0 ,Spring Boot 2.5.x开发实战是学习Java Spring Cloud微服务架构的必经之路。电子书+视频为同学带来最佳学习效果,文字、课程链接、图谱地址统统为大家放送了哦

哈喽各位同学们大家好呀,今天小编为大家分享开发者学院中课程Spring Boot 2.5实战Redis分布式缓存6.0 ”干货总结哦~Spring Boot 2.5.x开发实战可Java中级工程师必备课程!

课程链接以及图谱地址小编已经为大家指路了,搭配学习效果更佳👇

课程名称:Spring Boot 2.5.x开发实战

课程地址:https://developer.aliyun.com/learning/course/71?spm=a2c6h.21254954.0.0.4e905907uoWZzr

图谱名称:Alibaba Java 技术图谱

图谱地址:https://developer.aliyun.com/graph/java?spm=a2c6h.21110250.J_5703890090.6.700e3c67EjOBeJ


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


)Spring Boot 2.5.x战分布式缓存Redis 6.0  

1Spring Data Redis6.0 

image.png 

Spring boot项目集成非常重要的缓存技术,头部新兴的互联网公司,大量使用开源缓存非常普遍本身Redis免费功能特性越来越完善,无论在基础功能使用还是丰富的数据类型高级功能主从集群模式高可用集群以及分辨集群等方面的知识都非常好,现在也在扩展消息推送以及分布式事务等新的特性知识 

Redis整个生态相对来说比较完善,无论是Java语言还是其他编程语言,另外比较重要的Java驱动工具驱动库Redis的链接池,使用的是比较有名的Java社群Jedis 

Spring Boot为后续的Java应用开发作铺垫Spring data for Redis系列接做了抽象,本质上 JavaRedis有基础Redis的驱动,使用基础的网络链接Redis服务进行交互,Redis使用单机点模式生产环境一般使用主重高可用或面集群模式,可以加设一台虚拟机安装完成。Java链接远程RedisRedis服务器端要允许远程端口链接,生产环境下安全验证 

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

1. 支持多种Redis驱动程序/连接器的低级抽象(JedisLettuceJRedisSRP期)  

2. Spring Data Access exceptionRedis driver exceptions转换  

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

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

MessageListenerContainer  

5. 支持Redis SentinelRedis Cluster集群模式  

6. JDKStringJSONSpring Object / XML映射序列化器  

7. 基于RedisJDK Collection实现  

8. Atomic counter原子计数器  

9. Sorting and Pipelining功能  

10.专门API支持SORTSORT / GET模式和返回批量值数据  

11.Redis实现了Spring 3.1缓存抽象  

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

13.支持存储库的CDI 

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

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

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

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

3Redis API  

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

4RedisConnection解析  

1. RedisConnectionRedis通信提供核心组件  

2. 处理与Redis服务器后端的通信 

3. 自动将底层连接异常转换为Spring DAO异常  

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

5. 操作语义保持不变。  

6. 统一接口  

7. 工厂模式  

8. 仓储模式 

 

()Spring Data for Redis架构 

1Java Spring Data for Redis架构 

image.png 

2RedisTemplate 

Interface            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  

1Linux安装Redis 6.2  

1.下载安装  

$ wget https://download.redis.io/releases/redis-6.2.1.tar.gz  

$ tar xzf redis-6.2.1.tar.gz  

$ cd redis-6.2.1  

$ make  

2.启动服务器  

$ src/redis-server  

3.启动命令客户端  

$ src/redis-cli  

4.新增查询Key value  

redis> set 1 java  

OK  

redis> get 1  

•“java" 

2Linux启动Redis Server 

image.png 

Redis Reactive Driver 

image.png 

 

image.png 

image.png 

image.png 

如上图所示MangoDBMySQL差不多,加了一个控制器里面实际放的一个是新增,一个是查询查询调的是redis仓储类型,里面赖注入,接口是自定义的一些方法,实现加了redisTemplate类型,用这个模板类型redis对象操作,主要做基础的增删改查基本操作用较新的默认版本通过依赖加了jedisSpring Boot2.5以后会自动版本兼容自动数据pageRedis对应的一些参数可以从page文件里进行数据读取,也可以写死 bean的构造方法可以指定传主机名传端口这两个参数通过value注解的方式配置文件自动加载完成 

image.png 

image.png 

image.png 

如上图所示,启动完以后要验证整个项目6.0.8版本,属于单点独立模式启动只有一个节点是为了方便调整,如果做远程链接, Ip保护模式限制要解除,需要修改IP如果不喜欢用命令行可以用可视化工具 

image.png 

如上图所示测试 Ad user保存多少,调用接口,保存100个用户,代码控制器跟之前差不多get by ID  add user for循环构造100个用户,插入 list,后面get ALL实际调 repository的仓储对象做查询操作 

注意第一步Activities先启动后配置网络和安全模式,必须远程链接客户端才能够进行链接操作 

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
2月前
|
Java API 数据库
构建RESTful API已经成为现代Web开发的标准做法之一。Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐。
【10月更文挑战第11天】本文介绍如何使用Spring Boot构建在线图书管理系统的RESTful API。通过创建Spring Boot项目,定义`Book`实体类、`BookRepository`接口和`BookService`服务类,最后实现`BookController`控制器来处理HTTP请求,展示了从基础环境搭建到API测试的完整过程。
48 4
|
16天前
|
存储 运维 安全
Spring运维之boot项目多环境(yaml 多文件 proerties)及分组管理与开发控制
通过以上措施,可以保证Spring Boot项目的配置管理在专业水准上,并且易于维护和管理,符合搜索引擎收录标准。
30 2
|
2月前
|
XML Java 数据格式
提升效率!Spring Boot 开发中的常见失误轻松规避
本文深入探讨了在 Spring Boot 开发中常见的失误,包括不当使用注解、不良异常处理、低效日志记录等,提供了有效的规避策略,帮助开发者提升代码质量和系统性能,构建更健壮、高效的应用程序。
|
21天前
|
安全 Java 测试技术
Java开发必读,谈谈对Spring IOC与AOP的理解
Spring的IOC和AOP机制通过依赖注入和横切关注点的分离,大大提高了代码的模块化和可维护性。IOC使得对象的创建和管理变得灵活可控,降低了对象之间的耦合度;AOP则通过动态代理机制实现了横切关注点的集中管理,减少了重复代码。理解和掌握这两个核心概念,是高效使用Spring框架的关键。希望本文对你深入理解Spring的IOC和AOP有所帮助。
31 0
|
3月前
|
人工智能 开发框架 Java
重磅发布!AI 驱动的 Java 开发框架:Spring AI Alibaba
随着生成式 AI 的快速发展,基于 AI 开发框架构建 AI 应用的诉求迅速增长,涌现出了包括 LangChain、LlamaIndex 等开发框架,但大部分框架只提供了 Python 语言的实现。但这些开发框架对于国内习惯了 Spring 开发范式的 Java 开发者而言,并非十分友好和丝滑。因此,我们基于 Spring AI 发布并快速演进 Spring AI Alibaba,通过提供一种方便的 API 抽象,帮助 Java 开发者简化 AI 应用的开发。同时,提供了完整的开源配套,包括可观测、网关、消息队列、配置中心等。
2399 14
|
2月前
|
Java 数据库连接 Spring
【2021Spring编程实战笔记】Spring开发分享~(下)
【2021Spring编程实战笔记】Spring开发分享~(下)
30 1
|
2月前
|
开发框架 Java API
「SpringBrick快速入门指南」:一款基于Spring Boot的高级插件化开发框架
「SpringBrick快速入门指南」:一款基于Spring Boot的高级插件化开发框架
60 0
|
2月前
|
XML Java 数据格式
手动开发-简单的Spring基于注解配置的程序--源码解析
手动开发-简单的Spring基于注解配置的程序--源码解析
47 0
|
2月前
|
XML Java 数据格式
手动开发-简单的Spring基于XML配置的程序--源码解析
手动开发-简单的Spring基于XML配置的程序--源码解析
82 0
|
2月前
|
XML Java 数据库连接
【2020Spring编程实战笔记】Spring开发分享~(上)
【2020Spring编程实战笔记】Spring开发分享~
53 0