java最新Springboot3+微服务实战12306高性能售票系统全套开发课程
视频课程在文末获取
第1章 课程介绍与学习指南。
1-1 课前必读(不读错过一个亿)
1-2 课程导学
1-3 为什么要选择最新版本SpringBoot3和JDK17?
1-4 在线demo网站演示
第2章 12306这个系统架构到底有多牛?
2-1 众多流行并发项目,为何选择12306?
2-2 12306 是如何成为全球最忙碌的网站之一
2-3 如何保证不超卖、不少卖,还要能承受极高的并发?
2-4 12306系统核心功能讲解
2-5 12306系统功能模块划分
2-6 12306整体系统架构设计
2-7 12306系统数据库表讲解
2-8 百万人同时抢1万张票,系统如何保证其正常及稳定性?
第3章 最新版的SpringBoot3&JDK9~17新特性详解14 节
3-1 JDK9新特性-jshell交互式工具(加片头)
3-2 JDK9新特性-模块化开发
3-3 JDK10新特性-var局部变量推导
3-4 JDK11新特性-单文件程序
3-5 JDK11新特性-shebang脚本
3-6 JDK14新特性-文本块
3-7 JDK14新特性-instanceof增强
3-8 JDK14新特性-空指针提示
3-9 JDK16新特性-record类
3-10 JDK17新特性-sealed类
3-11 JDK17新特性-switch增强
3-12 SpringBoot3-AOT与JIT介绍
3-13 JIT在高并发场景中的生产问题分享
3-14 SpringBoot3-GraalVM代替JDK实现AOT
第4章 新版Spring Cloud Alibaba与Springbooot搭建后端架构20 节
4-1 手把手快速完成微服务架构的搭建(加片头)
4-2 项目初始化配置
4-3 实现代码关联Git远程仓库
4-4 新增member会员模块
4-5 实现日志的相关配置
4-6 使用HTTP Client完成测试接口
4-7 增加AOP打印请求参数和返回结果
4-8 详解项目中增加通用模块
4-9 详解项目中增加网关模块
4-10 详解本地数据库的准备工作
4-11 详解阿里云RDS的准备工作
4-12 使用IDEA配置数据库连接
4-13 集成Mybatis持久层框架
4-14 集成Mybatis官方生成器
4-15 完成会员注册接口的开发
4-16 封装请求参数和返回结果
4-17 为项目增加统一异常处理
4-18 使用自定义异常处理异常业务
4-19 集成校验框架Validation
4-20 详解雪花算法
第5章 使用Vue3 + Vue CLI 实现系统前端模块的搭建13 节
5-1 本章介绍(加片头)
5-2 本地环境准备
5-3 手把手创建基于Vue CLI的web模块
5-4 web模块集成Ant Design Vue
5-5 短信验证码登录流程讲解
5-6 注册登录二合一界面开发
5-7 发送短信验证码接口开发
5-8 短信验证码登录接口开发
5-9 集成Axios完成登录功能
5-10 增加Axios拦截器配置
5-11 Vue CLI多环境配置
5-12 增加web控台主页
5-13 制作Vue3公共组件
第6章 实现JWT单点登录功能10 节
6-1 本章介绍
6-2 介绍两种单点登录方案设计
6-3 JWT单点登录原理与存在的问题及解决方案讲解
6-4 详解生成JWT单点登录token
6-5 使用vuex保存登录信息
6-6 vuex配合h5的session解决浏览器刷新问题
6-7 演示gateway拦截器的使用
6-8 为gateway增加登录校验拦截器
6-9 为axios请求增加统一拦截器
6-10 为路由页面增加登录拦截
第7章 12306系统会员基础功能的实现18 节
7-1 本章介绍
7-2 详解乘车人表的设计
7-3 乘车人新增接口开发
7-4 使用HttpClient保存登录信息
7-5 使用线程本地变量存储会员信息
7-6 前端二级路由页面开发
7-7 乘车人新增界面开发
7-8 乘车人列表查询接口开发
7-9 集成PageHelper实现后端分页(一)
7-10 集成PageHelper实现后端分页(二)
7-11 乘车人列表查询界面开发(一)
7-12 乘车人列表查询界面开发(二)
7-13 解决Long类型精度丢失的问题
7-14 乘车人编辑接口开发
7-15 乘车人编辑界面开发
7-16 乘车人删除接口开发
7-17 乘车人删除功能开发
7-18 前端枚举展示的解决方案介绍
第8章 自制前后端代码生成器提高开发效率11 节
8-1 本章介绍
8-2 更换RDS数据库
8-3 剖析代码生成器的底层原理
8-4 集成DOM4j读取xml
8-5 详解Service生成器
8-6 详解Controller生成器
8-7 制作DBUtil读取表字段信息
8-8 详解实体类生成器
8-9 按模块生成后端代码
8-10 详解vue界面生成器
8-11 详解前端枚举代码生成器
第9章 利用代码生成器快速实现火车基础数据的维护20 节
9-1 本章介绍
9-2 更换远程代码仓库
9-3 项目中增加admin控台模块
9-4 项目中增加business业务模块
9-5 为business模块配置持久层生成器
9-6 快速生成车站基础数据
9-7 快速生成火车基础数据管理功能
9-8 快速生成火车车站基础数据管理功能
9-9 快速生成火车车厢基础数据管理功能
9-10 快速生成火车座位基础数据管理功能
9-11 使用pinyin-pro将汉字转成拼音
9-12 车次表单增加车站下拉选择
9-13 制作车次下拉框组件(一)
9-14 制作车次下拉框组件(二)
9-15 制作车站下拉框组件
9-16 为基础数据增加车次查询条件
9-17 实现按车次生成车座功能(一)
9-18 实现按车次生成车座功能(二)
9-19 完善车次&车厢&座位管理功能
9-20 为车次&车厢&车站增加存在性校验
第10章 使用调度框架quartz,为12306系统增加定时调度功能10 节
10-1 本章介绍
10-2 项目中增加batch定时调度模块
10-3 为batch模块配置持久层生成器
10-4 演示Springboot自带的定时任务
10-5 定时调度模块集成quartz
10-6 关于调度任务的并发执行
10-7 使用数据库配置quartz调度任务
10-8 通过控台界面操作定时任务
10-9 增加任务手工补偿功能
10-10 演示多节点场景中quartz的调度情况
第11章 通过火车基础数据生成每日火车数据13 节
11-1 本章介绍
11-2 快速生成每日车次数据管理功能
11-3 完善每日车次管理页面功能
11-4 快速生成每日车站数据管理功能
11-5 快速生成每日车厢数据管理功能
11-6 快速生成每日座位数据管理功能
11-7 增加生成每日车次定时任务
11-8 集成OpenFeign实现服务间调用
11-9 增加生成每日车次功能
11-10 增加生成每日车站功能
11-11 增加生成每日车厢功能
11-12 增加生成每日座位功能
11-13 增加手动生成某日车次数据功能
第12章 基本的车票预定功能开发24 节
12-1 本章介绍
12-2 增加余票信息表以提高余票查询效率
12-3 生成车次时初始化余票信息
12-4 生成车次时初始化各种座位的余票数量
12-5 为余票信息页面增加查询条件
12-6 为会员端增余票查询功能
12-7 增加订票页面并实现车次信息传递
12-8 订票页面勾选乘客并显示购票列表
12-9 分解选座购票功能的前后端逻辑
12-10 订票页面增加选座效果
12-11 增加确认订单表并生成前后端代码
12-12 后端增加确认下单购票接口
12-13 确认下单接口数据初始化
12-14 预扣减库存并判断余票是否足够
12-15 计算多个选座之间的偏移值
12-16 循环获取每个车厢的每个座位
12-17 根据座位销售详情判断本次是否可选(一)
12-18 根据座位销售详情判断本次是否可选(二)
12-19 完成有选座的挑座位逻辑
12-20 保存最终的选座结果
12-21 选座成功后更新各座位的销售详情
12-22 选座成功后批量扣减影响到的多个库存
12-23 选座成功后会会员增加车票记录
12-24 选座成功后更新确认订单状态为成功
第13章 集成注册中心与配置中心组件Nacos(动态修改线上的配置)10 节
13-1 本章介绍
13-2 Nacos官网介绍
13-3 Nacos快速开始
13-4 Nacos配置中心演示
13-5 Nacos多环境配置演示
13-6 Nacos利用命名空间做项目隔离
13-7 Nacos注册中心演示
13-8 配置Gateway+Nacos支持应用名路由转发
13-9 配置Feign+Nacos支持应用名远程调用
13-10 Nacos挂了怎么办
第14章 高性能余票查询的实现(前端缓存&本地缓存&分布式缓存)10 节
14-1 本章介绍
14-2 详解Mybatis的一级缓存
14-3 详解Mybatis的二级缓存
14-4 详解SpringBoot内置缓存
14-5 SpringBoot整合redis缓存
14-6 详解缓存击穿与解决方案
14-7 详解缓存穿透与解决方案
14-8 详解缓存雪崩与解决方案
14-9 缓存在高并发场景中的生产问题分享
14-10 前端缓存的使用
第15章 集成分布式事务组件Seata(解决分布式系统中的数据一致性问题)8 节
15-1 本章介绍
15-2 初识Seata
15-3 讲解Seata分布式事务的原理
15-4 讲解Seata分布式事务的四种模式
15-5 Seata分布式事务初体验
15-6 Seata Server配置Nacos
15-7 Seata Client配置Nacos
15-8 Seata和Mysql存储演示
第16章 高并发抢票时,利用各种锁解决车票超卖问题(JDK锁&分布式锁&看门狗设计&红锁)9 节 |
16-1 本章介绍
16-2 JMeter初体验
16-3 超卖演示&使用JMeter对购票功能进行压测
16-4 使用synchronized是否能解决库存超卖?
16-5 使用Redis分布式锁是否能解决库存超卖?
16-6 使用Redisson看门狗解决锁超时的问题
16-7 介绍Redis红锁
16-8 本章代码优化
16-9 JMeter线程组之间传递token变量
第17章 高并发抢票时,使用Sentinal组件进行请求限流降级(过滤90%的无效请求)12 节
17-1 本章介绍
17-2 常见的限流算法
17-3 初识Sentinel
17-4 Sentinel限流初体验
17-5 使用Sentinel控台监控流量
17-6 使用Sentinel配置限流
17-7 Sentinel+Nacos实现限流规则持久化
17-8 Sentinel限流不同的流控效果讲解 - Warm Up&排队等待
17-9 Sentinel限流不同的流控模式讲解 - 关联&链路
17-10 Sentinel+Feign熔段初体验
17-11 Sentinel+Feign熔断后的降级处理
17-12 Sentinel熔断规则配置演示
第18章 高并发抢票时,防止机器人刷票的令牌大闸,可减轻服务器的压力(防刷+限流)8 节
18-1 本章介绍
18-2 增加秒杀令牌表用以维护令牌信息
18-3 初始化车次信息时初始化秒杀令牌信息
18-4 增加校验秒杀令牌功能
18-5 使用令牌锁防止机器人抢票
18-6 使用缓存加速令牌锁功能
18-7 增加验证码削弱瞬时高峰并防机器人刷票
18-8 增加第一层验证码削弱瞬时高峰
第19章 利用流行的MQ组件对请求做削峰处理,解决吞吐量问题(实现最短时间内给用户反馈)12 节
19-1 本章介绍
19-2 购票时序图演进
19-3 初始RocketMQ
19-4 RocketMQ初体验
19-5 RocketMQ控制台的使用
19-6 使用RocketMQ将购票流程一分为二
19-7 完成MQ消费里的购票功能
19-8 为同转异增加logId,方便日志跟踪
19-9 增加排队功能思路讲解
19-10 完成排队出票功能(一)
19-11 完成排队出票功能(二)
19-12 增加轮询购票结果功能
第20章 压力测试-高并发优化前后的性能对比(单机性能提升25倍左右)7 节
20-1 本章介绍
20-2 压力测试相关概念讲解
20-3 吞吐量压测
20-4 旧代码吞吐量压测
20-5 修改JVM参数再次压测
20-6 最高并发数探测
20-7 使用异步线程代替RocketMQ
第21章 企业级项目上云(阿里云部署)17 节
21-1 本章介绍
21-2 阿里云部署方案介绍
21-3 阿里云RDS购买与配置
21-4 阿里云Redis购买
21-5 阿里云ECS购买与配置
21-6 本地登录阿里云ECS
21-7 安装JDK
21-8 安装nacos
21-9 SpringBoot应用的多环境打包
21-10 SpringBoot应用的生产发布
21-11 Vue CLI模块的生产打包
21-12 Vue CLI模块的生产发布
21-13 修复服务端访问失败的问题
21-14 多节点的配置,保证服务高可用(一)
21-15 多节点的配置,保证服务高可用(二)
21-16 cdn配置介绍
21-17 https配置介绍
第22章 项目优化9 节
22-1 本章介绍
22-2 购票页面增加取消排队的功能
22-3 余票查询页面增加显示车站信息
22-4 购票页面增加发起多人排队功能
22-5 增加座位销售图(一)
22-6 增加座位销售图(二)
22-7 只允许购买两周内的车次
22-8 增加乘客初始化定时任务(为了线上体验)
22-9 界面显示优化
第23章 课程总结1 节
23-1 课程总结