疯狂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

  1. 为了实现流程,定义操作Cookie工具类
  2. 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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/58668.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

『 Linux 』网络传输层 - TCP(二)

文章目录 TCP六个标志位TCP的连接三次握手 四次挥手为什么是三次握手和四次挥手 重传机制 TCP六个标志位 在TCP协议报文的报头中存在一个用于标志TCP报文类型的标志位(不考虑保留标志位),这些标志位以比特位选项的方式存在,即对应标志位为0则表示为假,对应标志位为1则为真; SYN…

LeetCode --- 421周赛

题目列表 3334. 数组的最大因子得分 3335. 字符串转换后的长度 I 3336. 最大公约数相等的子序列数量 3337. 字符串转换后的长度 II 一、数组的最大因子得分 数据范围足够小&#xff0c;可以用暴力枚举移除的数字&#xff0c;得到答案&#xff0c;时间复杂度为O(n^2)&#…

动态规划-回文串问题——5.最长回文子串

1.题目解析 题目来源&#xff1a;5.最长回文子串——力扣 测试用例 2.算法原理 1.状态表示 判断回文子串需要知道该回文子串的首尾下标&#xff0c;所以需要一个二维数组且数据类型为bool类型来存储每个子字符串是否为回文子串&#xff0c; 即dp[i][j]:以第i个位置为起始&a…

【AI日记】24.10.31 学习LangChain和寻找AI研究报告(比如麦肯锡)

【AI论文解读】【AI知识点】【AI小项目】【AI战略思考】【AI日记】 工作 工作1 内容&#xff1a;学习deeplearning.ai的免费课程地址&#xff1a;LangChain for LLM Application DevelopmentB站中英文地址&#xff1a;https://www.bilibili.com/video/BV1TJ4zemETf时间&#…

微积分复习笔记 Calculus Volume 1 - 4.4 The Mean Value Theorem

4.4 The Mean Value Theorem - Calculus Volume 1 | OpenStax

docker engine stopped

1&#xff09;环境&#xff1a;win 10 2&#xff09;docker安装时已经已经安装了虚拟机 3&#xff09;启用网络适配器 4&#xff09;启用docker服务&#xff08;依赖服务LanmanServer&#xff09; 5&#xff09;全都弄好了&#xff0c;docker还是打不开&#xff0c;没办法了&a…

【VM实战】VMware迁移到VirtualBox

VMware 虚拟机开机卸载VMware Tools 调整虚拟磁盘 对于Windows 10及以上的虚拟机&#xff0c;一般VMware默认都会选Nvme固态硬盘。在导出前必须将其改为SATA&#xff0c;否则VirtualBox导入会报Appliance Import错误 (E_INVALIDARG 0x80070057) 先删掉当前盘的挂载&#xff…

某本书上的一张序列图评点

贝贝 2019-8-24 10:56 潘老师&#xff0c;这个图是不是不太对。插卡&#xff0c;输入密码并不是ATM的职责&#xff1f; UMLChina潘加宇: 这种图用建模思维一挤压&#xff0c;脓包太多了。 问题一、几个生命线上的实例&#xff0c;抽象级别不一致。 ATM用户--系统&#xff0…

Docker | 校园网上docker pull或者docker run失败的一种解决方法

场景 需要从仓库拉取镜像 无论使用命令docker pull 还是 docker run 但是总是显示如下的错误: 解决方法 查看虚拟机网络连接方式 Linux上检查校园网是否登录 有界面 无界面 只是命令行操作的Linux 关于Linux服务器端更新命令apt update没有效果问题总结(校园网认证)

推荐一款功能强大的AI实时变声器:FliFlik Voice Changer

FliFlik VoiCE Changer是一款专注于声音变换与音频处理的创新软件&#xff0c;旨在满足从日常娱乐、游戏直播到播客制作、专业音频编辑的多种应用场景需求。无论是想在游戏中变换声音逗乐队友&#xff0c;还是在播客中塑造个性化的音效&#xff0c;这款软件都能提供灵活而强大的…

Java第二阶段---15异常---第三节 自定义异常

1. 为什么要使用自定义异常 在Java中&#xff0c;异常的类型非常的多&#xff0c;要想使用这些异常&#xff0c;首先必须要熟悉它们。这无疑是一个巨大的工作量&#xff0c;很耗费时间。如果我们可以自定异常&#xff0c;则只需要熟悉 RuntimeException 、 Exception 和 Throw…

【2】Elasticsearch 查询从基础到高级

文章目录 一、引言二、常用查询方式(一)简单查询(二)聚合查询(三)复杂查询三、查询关键词(一)比较关键词(二)逻辑关键词(三)其他关键词四、常用统计类查询(一)计数统计(二)平均值统计五、总结一、引言 Elasticsearch是一款强大的分布式搜索和分析引擎,在数据…

【前端】在 Next.js 开发服务器中应该如何配置 HTTPS?

在 Next.js 的开发环境中&#xff0c;默认情况下是使用 HTTP 协议的。但是&#xff0c;您可以通过一些配置来启用 HTTPS。这在开发阶段可能很有用&#xff0c;尤其是在需要测试涉及安全传输的应用场景时。 下面是如何在 Next.js 开发环境中配置 HTTPS 的步骤&#xff1a; 方法…

[供应链] 公开招标

公开招标(Public Invitation to Bid) 是招标采购方式的一种&#xff0c;通常在政府采购、工程项目或大型商业合同中使用 公开招标旨在通过市场竞争机制&#xff0c;选出最合适的供应商或承包商&#xff0c;确保项目能够以合理的价格、良好的质量以及规定的时间完成 公开招标也…

移植 AWTK 到 纯血鸿蒙(HarmonyOS NEXT)系统 (0) - 序

移植 AWTK 到 纯血鸿蒙 (HarmonyOS NEXT) 系统 (0) - 序 前段时间纯血鸿蒙系统 HarmonyOS 5.0&#xff08;又称 HarmonyOS NEXT&#xff09;正式推出&#xff0c;这是继苹果 iOS 和安卓系统后&#xff0c;全球第三大移动操作系统。纯正国产操作系统登场&#xff0c;国人无不欢…

沙盒正在源代码防泄漏行业盛行

SDC沙盒技术采用了零信任的核心理念——“永不信任&#xff0c;总是验证”。这意味着对每一个访问请求都进行严格的身份验证和授权&#xff0c;无论请求来自内部还是外部。SDC沙盒提供了一个隔离的环境&#xff0c;用于隔离本机&#xff0c;实现一机两用&#xff0c;起到保护系…

Go Modules和 雅典项目

本篇内容是根据2016年9月份Go modules and the Athens project音频录制内容的整理与翻译, 小组成员 Mat Ryer 和 Carmen Andoh 以及客座小组成员 Marwan Sulaiman 和 Aaron Schlesinger 一起讨论 Go 模块和 Athens 项目。 过程中为符合中文惯用表达有适当删改, 版权归原作者所…

YOLOv8改进,YOLOv8改进损失函数采用SlideLoss来处理样本不平衡问题,助力涨点

摘要 作者提出了一种基于 YOLOv5 改进的实时人脸检测模型,称为YOLO-FaceV2。设计了一个感受野增强模块(RFE)来提升小尺度人脸的感受野,并引入了 NWD 损失,以弥补 IoU 在小目标位置偏差上的敏感性。针对人脸遮挡问题,提出了 SEAM 注意力模块,并引入了排斥损失进行优化。…

【django】django RESTFramework前后端分离框架快速入门

目录 一、搭建项目开发环境 1.1 pycharm创建项目 1.2 修改配置settings.py 1.3 新增 static与staticfiles文件夹 1.4 生成数据表 1.5 创建超级用户 1.6 启动项目 二、安装REST_Framework 2.1 安装 2.2 配置settings 2.3 重新执行生成数据库脚本 三、修改路由 四、s…

【微服务】Java 对接飞书多维表格使用详解

目录 一、前言 二、前置操作 2.1 开通企业飞书账户 2.2 确保账户具备多维表操作权限 2.3 创建一张测试用的多维表 2.4 获取飞书开放平台文档 2.5 获取Java SDK 三、应用App相关操作 3.1 创建应用过程 3.2 应用发布过程 3.3 应用添加操作权限 四、多维表应用授权操作…