疯狂Spring Boot讲义[推荐1]
《疯狂Spring Boot讲义》是2021年电子工业出版社出版的图书,作者是李刚
《疯狂Spring Boot终极讲义》不是一本介绍类似于@PathVariable、@MatrixVariable、@RequestBody、@ResponseBody这些基础注解的图书,它是真正讲解Spring Boot的图书。Spring Boot的核心是什么?它的核心就是自动配置,以及以自动配置为基础与大量第三方后端技术进行整合。因此学习Spring Boot应该重点关注的就是它为整合各种框架所提供的自动配置,包括Spring Boot如何整合各种前端框架,如Spring MVC、Spring WebFlux;Spring Boot如何整合各种持久层技术,如Spring Data、MyBatis、Hibernate/JPA、R2DBC、jOOQ等;Spring Boot如何整合NoSQL技术,如Redis、MongoDB、Neo4j、Cassandra、Solr、Elasticsearch等;Spring Boot如何整合各种消息组件,如ActiveMQ、Artemis、RabbitMQ、Kafka等;Spring Boot如何整合各种缓存机制,如JCache、EhCache、Redis、Hazelcast等;Spring Boot如何整合各种安全框架,如Spring Security、Shiro等,这些都只是Spring Boot整合的典型内容。本书的作用就是带你彻底掌握Spring Boot官方手册中所整合的各种技术,而且本书会讲清楚Spring Boot和Spring框架的关系,带着你揭开Spring Boot的核心:自动配置的面纱,领着你剖析Spring Boot自动配置的源代码实现,然后以此为基础,详细讲解Spring Boot如何整合各种Java后端技术。在掌握了本书知识之后,你不仅能轻松看懂Spring Boot官方手册(其实无须再看了),而且真正掌握了Spring Boot的大成,并通过Spring Boot的整合触类旁通地掌握各种Java后端技术。本书提供了读者答疑交流群,读者可通过扫描本书封面上的二维码,按照指引加入读者答疑交流群。

技术示范:高并发请求提供及时响应,对秒杀请求的瞬时高并发进行削峰限流
项目背景
- 电商在特殊时间节点做促销活动,参与商品的价格实惠,用户特意等到活动期间购买
- 从而很容易引起瞬时的高并发请求的峰值情况
- 通常通过RabbitMQ消息组件进行削峰,即限制、延迟处理,避免服务器崩溃。
系统架构
| MVC | Spring MVC | 用户请求的处理与转发; 包括系统的超链接与表单提交 | 拦截器的权限控制 |
| 底层持久层 DAO层 | MyBatis | 简化,优化与封装 | SQL Mapping框架 Mapper接口 |
| NoSQL 分布式Session | Redis | 数据缓存、页面缓存 | |
| 消息组件 | RabbitMQ | 秒杀限流 | |
| 业务逻辑层 | Spring Boot | 整合与自动配置;业务逻辑组件 | 依赖注入;面向接口; IoC;声明式事务框架 |
| 表现层 | Thymeleaf | 收集用户请求数据; 业务数据表示 | |
| Bootstrap | 简单美化 | ||
| jQuery | JS工具库动态更新页面 |
功能模块
- 主要是用户模块和秒杀模块
- 业务逻辑组件为门面封装且依赖Mapper组件
| Mapper对象组件| 4 | UserMapper | user_inf |
| MiaoshaItemMapper | item_inf、miaoshao_inf | |
| OrderMapper | order_inf | |
| MiaoshaOrderMapper | order_inf、miaosha_order | |
| 业务逻辑组件| 2 | UserService | 用户登录、用户信息查看 |
| MiaoshaService | 商品查看、商品秒杀 | |
| 消息组件| 2 | MiaoshaSender | 向RabbitMQ消息队列发送消息 |
| MiaoshaReceiver | 接受RabbitMQ消息队列中的消息 | |
| 操作Redis组件| 1 | FkRedisUtil |
加工逻辑
项目搭建
- 通过Spring Boot整合框架的自动配置,只需要在pom.xml中添加对应依赖库
其他依赖库
| Apache Commons Pool2连接池 | 连接Redis |
| Common Lang 3 | StringUtils、ArrayUtils、ClassUtils、RegExUtils工具类 |
| Common Codec | 编码、解码算法,如MD5加密算法 |
领域对象层
设计领域对象
- MyBatis的SQL Mapping进行持久化操作,从而保证面向对象方式开发
| user_inf | nickname not null;加盐加密 | |
| item_inf | 主键自增 | 商品名称、商品描述 |
| miaosha_item | 主键自增 | 基本信息; 秒杀价、库存、开始结束时间 |
| order_inf | 主键自增 | 订单用户、订单价格、下单时间 |
| miaosh_order | 主键自增; unique key(user_id, item_id)唯一约束 | 用户ID、订单ID、商品ID |
创建领域对象类
- MyBatis是结果集映射框架
- 只需要定义数据列的类实例变量以及setter、getter方法
Mapper(DAO)层
- MyBatis只需要通过XML文件定义Mapper接口的相关SQL语句就开发完成Mapper组件。
实现Mapper组件
- Mapper接口声明Mapper组件提供的持久化对象操作的CRUD方法
- 可能随着业务逻辑的需求而增加
| UserMapper接口 | 根据user_id查询user_inf; 更新user_inf | @Select(“SQL语句”) @Update(“SQL语句”) |
| MiaoshaItemMapper接口 | 更新库存 查询所有秒杀商品 查询指定秒杀商品 | @Result(参数) List<MiaoshaItem> @Param |
| OrderMapper接口 | 插入新纪录 获取订单 | @Insert(“SQL语句”) @Option(参数) |
| MiaoshaOrderMapper接口 | 获取秒杀订单 插入秒杀订单 |
部署Mapper组件
Spring Boot自动配置数据源、SqlSessionFactory基础组件,部署Mapper成容器的Bean
| spring.datasource | .driver-class-name | =com.mysql.cj.jdbc.Driver |
| .url | =mysql://localhost:3306/... | |
| .username | ||
| .password |
分布式Session及用户登录的实现
权限管理等采用分布式Session,高并发秒杀系统通常都是分布式应用,基于Redis实现
实现Redis组件
- 添加Spring Boot Data Redis,提供自动配置RedisConnectionFactory、StringRedisTmplate
- 注入其他组件即可
| spring.redis | host | ||
| port | |||
| database | |||
| password | |||
| lettuce.pool | .maxActive | ||
| .maxIdle | 空闲连接数 | ||
| .minIdle |
- 工具类对RedisTemplate封装
- 方便操作系统中的key-value对
- 包括添加key-value对、根据key获取对应的value、根据key删除指定key-value 对、判断指定的key是否存在等
| FkRedisUtil | get:获取相应的value | RedisTemplate: opsForValue: get |
| set:添加key-value对 | opsForValue: set: Duration.ofSeconds | |
| exists:key是否存在 | RedisTemplate: hasKey; | |
| delete:根据key删除 | RedisTemplate: delete | |
| incr | RedisTemplate: opsForValue: increment | |
| decr | RedisTemplate: opsForValue: decrement | |
| beanTostring | ObjectMapper.writeValueAsString; | |
| stringToBean | ObjectMapper.readValue |
- 控制前缀部分,避免重复
- 控制过期时间
| KeyPrefix | 定义prefix以及过期时间 |
便于KeyPrefix提供实现类,而作为基类
| AbstractPrefix | 设置过期时间 定义:类名:prefix |
分布式Session的实现
- Session ID发送浏览器,以Cookie保存[UUID]
- 服务器端用Redis保存key-value信息,以客户端的Session ID为key
- 对象:分布式Session
- 为了实现流程,定义操作Cookie工具类
- getSessionId工具方法就是分布式Session实现机制的第1步:通过Cookie来读取Session ID;如果读不到有效的Session ID,系统会生成一个随机的UUID作为Session ID,并将该Session ID 以Cookie的形式写入浏览器,交给浏览器保存。
| key | value | |
| Cookie | “token” | UUID |
| Redis | prefix+UUID | Session信息 |
| CookieUtil | addSessionID:以Cookie写入 | HttpServletResponse:addCookie Cookie: setMaxAge、setPath |
| getCookieValue:读取指定 | HttpServletRequest: getCookies() Cookie: getName、getValue | |
| getSessionId:读取,否则创建 | 对getCookieValue进一步封装 |
通过Redis缓存实现分布式Session
| UserController | addSession: 分别保存 | |
| getByToken:延长有效期、读取 |
只要任意控制器访问系统,拦截器就会向氛围中的浏览器写入Cookie,从而保存SessionID
| AccessInterceptor | preHandle:访问写入、保存 拦截所有控制器的处理方法 | HandlerInterceptor: preHandle |
| UserKey | key前缀以及有效时间 |
用户登录的实现
getLoginVerifyCode符合分布式的Session流程
| UserController | toLogin | |
| getLoginVerifyCode:验证码 | @GetMappring(method) HttpServletResponse:getOutputStream | |
| proLogin |
相关文章:
疯狂Spring Boot讲义[推荐1]
《疯狂Spring Boot讲义》是2021年电子工业出版社出版的图书,作者是李刚 《疯狂Spring Boot终极讲义》不是一本介绍类似于PathVariable、MatrixVariable、RequestBody、ResponseBody这些基础注解的图书,它是真正讲解Spring Boot的图书。Spring Boot的核心…...
vue中$nextTick的作用是什么,什么时候使用
$nextTick 是 Vue 提供的一个方法,用于在下一次 DOM 更新周期之后执行回调函数。它通常用于在 Vue 完成数据更新后,需要访问更新后的 DOM 状态时,保证操作的是更新后的 DOM。 工作原理: Vue 是异步更新 DOM 的,当数据…...
Redis实现全局ID生成器
全局ID生成器 为什么要用全局ID生成器 1.当我们使用数据库自增来实现id的生成时,规律过于明显,会给用户暴露很多信息 2.当我们订单量过大时无法用数据库的一张表来存放订单,如果两张表的id都是自增的话,id就会出现重复 什么是全局ID生成器 全局ID生成器,是一种在分布式系统…...
Xshell远程连接工具详解
Xshell是一款在Windows平台上运行的远程连接工具,它支持SSH1、SSH2以及Microsoft Windows平台的TELNET协议。Xshell通过互联网实现对远程主机的安全连接,帮助用户在复杂的网络环境中享受他们的工作。本文将详细介绍Xshell的溯源、最新版本以及它的优势。…...
如何在verilog设计的磁盘阵列控制器中实现不同RAID级别(如RAID 0、RAID 1等)的切换?
以下是一种在Verilog设计的磁盘阵列控制器中实现不同RAID级别(以RAID 0和RAID 1为例)切换的方法: 添加控制信号 在磁盘阵列控制器模块中添加一个输入信号,例如raid_mode,用于选择RAID模式。假设raid_mode = 0表示RAID 0模式,raid_mode = 1表示RAID 1模式。module raid_co…...
基于元神操作系统实现NTFS文件操作(十)
1. 背景 本文补充介绍文件遍历操作的部分附加内容,譬如,过滤掉系统元文件、过滤掉重复的文件项、过滤掉隐藏文件等,并提供了基于元神操作系统的部分实现代码。 2. 方法 (1)过滤掉系统元文件 NTFS文件系统的前16个元…...
Qt的几个函数方法
void receiveInfo1() {// 假设这是从串口接收到的字符串QString receivedString "23.5C,45%,1012hPa";// 使用逗号分隔符分割字符串QStringList parts receivedString.split(,);// 检查分割后的列表是否有足够的部分if (parts.size() > 3) {QString part1 part…...
openpnp - bug - 散料飞达至少定义2个物料
文章目录 openpnp - bug - 散料飞达至少定义2个物料笔记END openpnp - bug - 散料飞达至少定义2个物料 笔记 散料飞达上定义的物料个数用完了,现在只需要一个料就可以。 用顶部相机去找编带上是否还有一个单独的料,找到了。 定义散料飞达的料为1个&…...
HDFS异常org.apache.hadoop.hdfs.protocol.NSQuotaExceededException
HDFS异常org.apache.hadoop.hdfs.protocol.NSQuotaExceededException 异常信息: Hive:org.apache.hadoop.hdfs.protocol.NSQuotaExceededException: The NameSpace quota (directories and files) of directory /xxxdir is exceeded: quota10000 file count15001N…...
数据库的构成与手写简单数据库的探索
一、引言 在当今数字化的时代,数据库扮演着至关重要的角色。无论是企业管理系统、电子商务平台还是各种移动应用,都离不开数据库的支持。数据库是存储和管理数据的核心工具,它的高效性、可靠性和安全性对于数据的处理和应用至关重要。本文将…...
基于STM32的智能晾衣架设计
引言 随着智能家居的普及,智能晾衣架成为了提升生活便利性的重要设备。智能晾衣架通过集成多个传感器,能够自动感知天气变化、湿度、光照等环境因素,实现自动升降、风干和报警功能,帮助用户更加高效地晾晒衣物。本项目基于STM32设…...
【MAUI】模糊控件(毛玻璃高斯模糊亚克力模糊)
文章目录 XAML.CSToBytes方法使用效果 常试过AcrylicView.MAUI和Sharpnado.MaterialFrame,对于二者教程很少,使用直接写控件然后调属性,没有报错但也并没有效果所幸就自己写一个 XAML <?xml version"1.0" encoding"utf-…...
深度学习:pandas篇
1. Pandas 基础 Pandas 是一个帮助你处理和分析数据的工具 安装 Pandas pip install pandas 导入 Pandas,我们用 pd 来代替 Pandas 的全称,这样以后写代码的时候更简洁 import pandas as pd 建 Series 和 DataFrame Pandas 最基本的两个数据结构是…...
Redis学习文档(Redis基本数据类型【Hash、Set】)
Hash(哈希) 介绍 Redis 中的 Hash 是一个 String 类型的 field-value(键值对) 的映射表,特别适合用于存储对象,后续操作的时候,你可以直接修改这个对象中的某些字段的值。 Hash 类似于 JDK1.…...
15分钟学Go 第9天:函数的定义与调用
第9天:函数的定义与调用 欢迎来到第9天的Go语言学习模块!今天我们将深入探讨函数的定义与调用,帮助你掌握如何编写和使用函数。学习函数不仅是Go语言的基础,也是程序设计的核心概念之一。这一节将详细介绍函数的结构、参数传递、…...
Java虚拟机:JVM介绍
1024 程序员节日快乐!愿您我的代码永远没有 bug ,人生永远没有 bug ! JVM 概述JVM 架构 概述 JVM( Java Virtual Machine ,Java 虚拟机),是 Java 语言的运行环境,是运行所有 Java 程…...
R数据科学 16.5.3练习题
(1) 编写代码以使用一种映射函数完成以下任务。 a. 计算 mtcars 数据集中每列的均值。 b. 确定 nycflights13::flights 数据集中每列的类型。 c. 计算 iris 数据集中每列唯一值的数量。 d. 分别使用 μ -10、0、10 和 100 的正态分布生成 10 个随机数。 library(purrr) # 计算…...
通过conda install -c nvidia cuda=“11.3.0“ 安装低版本的cuda,但是却安装了高版本的12.4.0
问题 直接通过 conda install -c nvidia cuda"11.3.0"安装得到的却是高版本的 不清楚原理 解决方法 不过我们可以分个安装 runtime toolkit 和 nvcc 安装指定版本的 cudatoolkit 和 nvcc conda install -c nvidia cuda-cudart"11.3.58" conda instal…...
简易CPU设计入门:验证取指令模块
项目代码下载 还是请大家首先准备好本项目所用的源代码。如果已经下载了,那就不用重复下载了。如果还没有下载,那么,请大家点击下方链接,来了解下载本项目的CPU源代码的方法。 下载本项目代码 准备好了项目源代码以后ÿ…...
【MySQL数据库】MySQL主从复制
文章目录 MySQL主从复制MySQL主从复制的分类MySQL主从复制原理MySQL主从复制的配置步骤MySQL主从复制的同步模式 MySQL主从复制实验环境准备关闭防火墙和 SELinux时间同步主服务器设置从服务器设置 MySQL 主从复制配置主服务器配置从服务器配置(以 Slave1 为例&…...
利用ngx_stream_return_module构建简易 TCP/UDP 响应网关
一、模块概述 ngx_stream_return_module 提供了一个极简的指令: return <value>;在收到客户端连接后,立即将 <value> 写回并关闭连接。<value> 支持内嵌文本和内置变量(如 $time_iso8601、$remote_addr 等)&a…...
大话软工笔记—需求分析概述
需求分析,就是要对需求调研收集到的资料信息逐个地进行拆分、研究,从大量的不确定“需求”中确定出哪些需求最终要转换为确定的“功能需求”。 需求分析的作用非常重要,后续设计的依据主要来自于需求分析的成果,包括: 项目的目的…...
ios苹果系统,js 滑动屏幕、锚定无效
现象:window.addEventListener监听touch无效,划不动屏幕,但是代码逻辑都有执行到。 scrollIntoView也无效。 原因:这是因为 iOS 的触摸事件处理机制和 touch-action: none 的设置有关。ios有太多得交互动作,从而会影响…...
大语言模型(LLM)中的KV缓存压缩与动态稀疏注意力机制设计
随着大语言模型(LLM)参数规模的增长,推理阶段的内存占用和计算复杂度成为核心挑战。传统注意力机制的计算复杂度随序列长度呈二次方增长,而KV缓存的内存消耗可能高达数十GB(例如Llama2-7B处理100K token时需50GB内存&a…...
Pinocchio 库详解及其在足式机器人上的应用
Pinocchio 库详解及其在足式机器人上的应用 Pinocchio (Pinocchio is not only a nose) 是一个开源的 C 库,专门用于快速计算机器人模型的正向运动学、逆向运动学、雅可比矩阵、动力学和动力学导数。它主要关注效率和准确性,并提供了一个通用的框架&…...
AI+无人机如何守护濒危物种?YOLOv8实现95%精准识别
【导读】 野生动物监测在理解和保护生态系统中发挥着至关重要的作用。然而,传统的野生动物观察方法往往耗时耗力、成本高昂且范围有限。无人机的出现为野生动物监测提供了有前景的替代方案,能够实现大范围覆盖并远程采集数据。尽管具备这些优势…...
android13 app的触摸问题定位分析流程
一、知识点 一般来说,触摸问题都是app层面出问题,我们可以在ViewRootImpl.java添加log的方式定位;如果是touchableRegion的计算问题,就会相对比较麻烦了,需要通过adb shell dumpsys input > input.log指令,且通过打印堆栈的方式,逐步定位问题,并找到修改方案。 问题…...
作为测试我们应该关注redis哪些方面
1、功能测试 数据结构操作:验证字符串、列表、哈希、集合和有序的基本操作是否正确 持久化:测试aof和aof持久化机制,确保数据在开启后正确恢复。 事务:检查事务的原子性和回滚机制。 发布订阅:确保消息正确传递。 2、性…...
为什么要创建 Vue 实例
核心原因:Vue 需要一个「控制中心」来驱动整个应用 你可以把 Vue 实例想象成你应用的**「大脑」或「引擎」。它负责协调模板、数据、逻辑和行为,将它们变成一个活的、可交互的应用**。没有这个实例,你的代码只是一堆静态的 HTML、JavaScript 变量和函数,无法「活」起来。 …...
绕过 Xcode?使用 Appuploader和主流工具实现 iOS 上架自动化
iOS 应用的发布流程一直是开发链路中最“苹果味”的环节:强依赖 Xcode、必须使用 macOS、各种证书和描述文件配置……对很多跨平台开发者来说,这一套流程并不友好。 特别是当你的项目主要在 Windows 或 Linux 下开发(例如 Flutter、React Na…...
