“新版 Spring Boot 3.0 打造能落地的高并发仿 12306 售票系统(23章)”是一类典型的高并发 + 分布式系统实战课程。它的核心目标不是做个简单 CRUD,而是复刻类似火车票抢票这种极端高并发场景下的系统设计与实现。
下面给你一个系统化介绍,适合做课程说明或技术文章👇
一、项目定位
基于 Spring Boot 3.x 构建:
👉 一个“仿 中国铁路12306”的售票系统
重点不是 UI,而是:
- 高并发处理
- 分布式架构
- 数据一致性
- 系统稳定性
👉 一句话:用真实业务场景练高并发架构能力
二、为什么选“12306场景”?
因为它具备典型难点:
- 瞬时高并发(抢票)
- 库存有限(票数)
- 强一致性(不能超卖)
- 高可用(系统不能挂)
👉 几乎覆盖所有后端高级问题
三、技术栈(核心组合)
常见技术包括:
- Spring Boot 3.x(基础框架)
- Spring Cloud(微服务架构)
- MySQL(数据存储)
- Redis(缓存 + 限流)
- RabbitMQ 或 Kafka(消息队列)
- Nginx(负载均衡)
👉 这是典型互联网后端技术栈
四、系统核心模块
1. 用户与认证系统
- 注册 / 登录
- Token 鉴权(JWT)
- 会话管理
2. 车次与库存系统
- 车次查询
- 座位库存管理
- 余票计算
👉 难点:库存实时性
3. 抢票核心流程(重点)
典型流程:
用户请求 → 限流 → 校验库存 → 锁定库存 → 创建订单 → 支付 → 确认出票
关键问题:
- 如何避免“超卖”?
- 如何保证并发安全?
4. 订单系统
- 订单创建
- 状态流转(待支付 / 已支付 / 已取消)
- 超时取消
5. 支付与回调(模拟)
- 支付流程模拟
- 异步回调处理
五、高并发核心技术(课程精华)
✔ 1. 限流与削峰
使用 Redis:
- 令牌桶 / 漏桶算法
- 接口限流
👉 防止系统被压垮
✔ 2. 缓存设计
- 热点数据缓存(余票)
- 缓存预热
- 缓存穿透 / 击穿 / 雪崩解决
✔ 3. 分布式锁
解决库存并发问题:
- Redis 分布式锁
- Redisson
👉 确保同一时间只有一个线程扣库存
✔ 4. 消息队列(削峰填谷)
通过:
- RabbitMQ / Kafka
实现:
- 异步处理订单
- 流量削峰
✔ 5. 库存扣减策略(核心难点)
常见方案:
- 数据库乐观锁
- Redis 预扣库存
- 最终一致性方案
👉 核心目标:不超卖 + 高性能
✔ 6. 分布式事务
解决问题:
- 下单 + 扣库存 + 支付一致性
方案:
- 本地消息表
- 可靠消息最终一致性
✔ 7. 高可用设计
- 服务降级
- 熔断(Sentinel / Hystrix 思想)
- 自动恢复
六、进阶架构设计
微服务拆分
系统通常拆为:
- 用户服务
- 订单服务
- 库存服务
- 支付服务
基于 Spring Cloud 实现
负载均衡
通过 Nginx:
- 分发请求
- 提高吞吐量
数据库优化
- 分库分表
- 索引优化
- 读写分离
七、实战价值(重点)
这类项目的含金量非常高👇
✔ 1. 高并发经验
面试常问场景:
- 如何防止超卖?
- 如何设计抢票系统?
✔ 2. 分布式系统理解
你会真正理解:
- CAP 理论
- 一致性问题
- 系统设计权衡
✔ 3. 可写进简历的项目
示例:
基于 Spring Boot 3.0 实现高并发售票系统,支持限流、分布式锁、消息队列削峰,解决超卖问题
八、适合人群
- Java 后端开发(进阶)
- 想冲大厂的工程师
- 想掌握高并发架构的人
- 3–5 年经验开发者
九、课程难度
👉 ⭐⭐⭐⭐(中高级)
建议基础:
- Java
- Spring Boot
- MySQL
- Redis
十、一句话总结
这套“仿12306高并发售票系统”= 用真实极限场景,训练你成为能设计高并发系统的后端工程师。
课程截图:

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