SSM(Spring+SpringMVC+MyBatis)高并发优化思路

SSM(Spring+SpringMVC+MyBatis)框架集由Spring、MyBatis两个开源框架整合而成(SpringMVC是Spring中的部分内容)。常作为数据源较简单的web项目的框架。

学习课程的地址:https://www.imooc.com/learn/632

老师的GitHub地址:https://github.com/geekyijun/seckill

高并发发生在哪里?
分析整个系统流程,用户进行秒杀时最感兴趣的进入详情页进行秒杀。图中红色表示可能会出现高并发的点,绿色表示不会出现高并发。

为什么要单独获取系统时间?
用户进行大量刷新时,详情页会部署到CDN节点上,进行静态化处理同时包括静态资源(css/js等)。这样就难以获得系统的统一秒杀时间。

CDN(内容分发网络)加速用户获取数据的系统,部署在离用户最近的网络节点上,命中CDN不需要访问后端服务器,互联网公司一般自己搭建或租用CDN服务器。涉及到CDN知识,进公司后涉及到自然就会了。。。

获取系统时间不用进行优化,因为访问内存的速度相当快。

秒杀地址接口分析
       无法使用CDN,使用CDN一般是不便的资源,而这里返回秒杀地址是变化的。适合使用服务端缓存如redis等。

流程则是先访问redis,如果redis中没有再去数据库中寻找,即redis是数据库的一个映射(后面得学下redis。。。),这里涉及到一致性问题,使用超时穿透/主动更新的方法。

秒杀操作的优化分析
无法使用CDN,库存量缓存困难,一行数据竞争(热点商品)。

为什么说MySQL低效?测试里MySQL的一条update一秒钟可以进行4W多次,不算低。主要是因为行级锁,每个用户都进行update,进行事务操作,等待锁的过程变成了串行化的操作。行级锁是在commit之后释放,优化的方向则是如何减少行级锁的持有时间。

延迟的分析:物理上的距离、JVM的GC问题。将客户端运行在MySQL端。方案一:定制SQL方案,需要修改MySQL源码。方案二:使用存储过程,整个事务在MySQL端完成。(这一段需要查更多资料)。

总结
前端控制:暴露接口、按钮防重复

动静态数据分离:CDN缓存、后端缓存

事务竞争优化:减少事务锁时间

redis后端缓存优化
redis目前官网不支持Windows,不过微软做了一个win64的版本。

具体编码这里不贴出了(见GitHub:https://github.com/geekyijun/seckill),理解原理就好。需要用到高并发时候可以详细学习一下。大致的思路就是访问redis缓存有没有数据,有就直接读,没有再读数据库并更新redis缓存。一致性通过设置一段时间后redis失效(超时穿透)和更新数据库时同时更新redis缓存(主动更新)。

秒杀操作—并发优化
将update减库存和insert购买明细进行顺序调整,将减少行级锁的时间,不必担心insert的问题,因为减库存成功后才commit否则rollback。但是这么做减少一半的网络延时和GC时间。关注点在哪些事务的操作中对数据库的行级锁有竞争关系,将行级锁的更新压缩到最小。

深度优化:将逻辑判断直接以函数的形式写入MySQL。

-- 存储过程

-- 1:存储过程优化:事务行级锁持有的时间

-- 2:不要过度依赖存储过程(一般存在于银行,互联网公司很少使用,秒杀单有用的地方)

-- 3:简单的逻辑可以应用存储过程

-- 4:QPS:一个秒杀单6000/qps

GitHub上有这一段的源码。

系统的部署架构

讲解了关于高并发下秒杀的简单案例(当然现实比这个复杂的多),感谢大牛。

原文地址

原文地址:https://www.cnblogs.com/hofmann/p/10816031.html

时间: 2024-10-12 13:05:40

SSM(Spring+SpringMVC+MyBatis)高并发优化思路的相关文章

SSM:spring+springmvc+mybatis框架中的XML配置文件功能详细解释

SSM:spring+springmvc+mybatis框架中的XML配置文件功能详细解释 2016-04-14 23:40 13030人阅读 评论(2) 收藏 举报 分类: SSM(7) 这几天一直在整合SSM框架,虽然网上有很多已经整合好的,但是对于里面的配置文件并没有进行过多的说明,很多人知其然不知其所以然,经过几天的搜索和整理,今天总算对其中的XML配置文件有了一定的了解,所以拿出来一起分享一下,希望有不足的地方大家批评指正~~~ 首先   这篇文章暂时只对框架中所要用到的配置文件进行解

SSM(Spring + Springmvc + Mybatis)框架面试题

JAVA SSM框架基础面试题https://blog.csdn.net/qq_39031310/article/details/83050192 SSM(Spring + Springmvc + Mybatis)框架面试题 一.Spring面试题 1.Spring 在ssm中起什么作用? Spring:轻量级框架 作用:Bean工厂,用来管理Bean的生命周期和框架集成. 两大核心:1.IOC/DI(控制反转/依赖注入) :把dao依赖注入到service层,service层反转给action

SSM Spring SpringMVC Mybatis框架整合Java配置完整版

以前用着SSH都是老师给配好的,自己直接改就可以.但是公司主流还是SSM,就自己研究了一下Java版本的配置.网上大多是基于xnl的配置,但是越往后越新的项目都开始基于JavaConfig配置了,这也是写此文章的原因.不论是eclipse还是myeclipse 都没有集成mybatis的相关组件,Spring也没有对其进行兼容,所以说我们会用到一些mybatis提供的核心jar包.下面先看一下我们的项目结构,我先自建了一个集成spring4.1的 ssm web项目(红色箭头指向注意删除web.

使用intellij idea搭建MAVEN+SSM(Spring+SpringMVC+MyBatis)框架

基本概念 使用SSM(Spring,SpringMVC和Mybatis) 1.1.Spring Spring是一个开源框架,Spring是于2003 年兴起的一个轻量级的Java 开发框架,由Rod Johnson 在其著作Expert One-On-One J2EE Development and Design中阐述的部分理念和原型衍生而来.它是为了解决企业应用开发的复杂性而创建的.Spring使用基本的JavaBean来完成以前只可能由EJB完成的事情.然而,Spring的用途不仅限于服务器

SSM(Spring+SpringMVC+MyBatis)框架整合

1.项目结构: 2.相关jar包: 3.相关配置文件: (1)web.xml配置文件: <?xml version="1.0" encoding="UTF-8"?><web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance&q

ssm(spring,springmvc,mybatis)

1.配置web.xml <?xml version="1.0" encoding="UTF-8"?> <web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="h

搭建springboot的ssm(spring + springmvc + mybatis)的maven项目

最终项目目录结构 创建过程 1.创建开关SpringBootApplication 为了创建快速.我们使用idea自带的创建springboot来创建结构,当然创建普通的web项目也是可以的.(使用eclipse的同学可以按照一会的图来自己创建目录结构) 1.1 创建项目,按照图示进行选择 1.2 1.3 1.4 好了 我们的初始项目算是创建完成了.项目结构如下图所示,其中 Ssmspringboot2Application就是我们的开关文件 其实现在一个最简单的springboot项目我们已经

使用idea搭建Maven+SSM(Spring+SpringMVC+Mybatis)框架(一、使用Maven创建新工程)

一.新建Maven项目 1.如图创建简单java web application. 2.如图填写组织唯一标识和项目唯一标识 3.如图照做 4.点击finish即可完成项目创建,如图为创建好后的项目结构. 5.设置项目Modules 至于后面的path和dependencies可以按照默认的配置,当你用maven导入包后dependencies会自动配置,当然要是想自己添加本地包可以在dependencies中点击绿色的加号自己添加包,我们使用maven时很少用到这样的操作,只有在不使用maven

Spring+SpringMvc+Mybatis框架集成搭建教程

一.背景 最近有很多同学由于没有过SSM(Spring+SpringMvc+Mybatis , 以下简称SSM)框架的搭建的经历,所以在自己搭建SSM框架集成的时候,出现了这样或者那样的问题,很是苦恼,网络上又没有很详细的讲解以及搭建的教程.闲来无事,我就利用空闲时间来写这样一个教程和搭建步骤,来帮助那些有问题的小伙伴,让你从此SSM搭建不再有问题. 二.教程目录 1.Spring+SpringMvc+Mybatis框架集成搭建教程一(项目创建) 2.Spring+SpringMvc+Mybat