《高并发商城秒杀项目》笔记
慕课网开源项目,基于 SpringBoot MyBatis 框架实现商城秒杀系统,支持短时大量突发访问。
使用 redis 做缓存提高访问速度和并发量,减少数据库压力;使用分布式Seesion,让多台服务器可以响应;使用消息队列完成异步下单,提升用户体验,削峰和降流。
-
开发语言
Java,主要应用Java的基本语法,Java面向对象的三大特征。 -
开发工具
JDK8,或者更高版本的JDK。 -
项目源码
https://github.com/zaki-zhu/b-.git -
项目教程
https://www.bilibili.com/video/BV1Ha4y1e7Uj?from=search&seid=16118878372930697789 -
参考资料
https://blog.csdn.net/weixin_42687829/article/details/104535027 -
个人项目地址
0 项目概述
0.1 项目技术点
0.2 秒杀业务分析
应对大并发的常见思路:
- 合理利用缓存——加缓存
- 合理使用异步——异步化
主要技术在业务中的应用:
基于SpringBoot MyBatis框架实现的商城秒杀系统,支持短时大量突发访问
使用分布式Seesion,让多台服务器也可以响应
使用redis做缓存提高访问速度和并发量,减少数据库压力
使用消息队列完成异步下单,提升用户体验,削峰和降流
使用页面伪静态化,缓存页面至浏览器,前后端分离降低服务器压力
安全性优化:
双重md5密码校验,秒杀接口地址的隐藏,接口限流防刷,数学公式验证码
1 项目框架搭建
1.1 Spring Boot环境搭建
Spring Boot是目前在java中最流行、最成熟的微服务框架。
Spring Boot的理念是0配置,而Spring MVC在使用中需要进行各种各样的配置。
Quick start:https://spring.io/quickstart
References:https://docs.spring.io/spring-boot/docs/
1.2 集成Thymeleaf页面模板
集成Thymeleaf页面模板,对输出结果进行封装。
1.3 集成Mybatis+Druid
1.4 集成Jedis+Redis安装
集成Jedis+Redis安装,练习实现通用缓存key的封装。
2 实现登录功能
2.1 数据库设计
2.2 明文密码两次MD5处理
2.3 JSR303参数检验
2.4 分布式Session
3 实现登录功能
3.1 数据库设计
3.2 商品列表页
3.3 商品详情页
3.4 订单详情页
4 JMeter压测
4.1
4.2
4.3
4.4
5 页面优化技术
5.1
5.2
5.3
5.4
6 接口优化