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上有这一段的源码。

系统的部署架构

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

原文地址

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

  1. Spring+SpringMVC+MyBatis+easyUI整合优化篇(二)Log4j讲解与整合

    日常啰嗦 上一篇文章主要讲述了一下syso和Log间的一些区别与比较,重点是在项目的日志功能上,因此,承接前文<Spring+SpringMVC+MyBatis+easyUI整合优化篇(一)Sy ...

  2. SSM(Spring+SpringMVC+Mybatis)框架环境搭建(整合步骤)(一)

    1. 前言 最近在写毕设过程中,重新梳理了一遍SSM框架,特此记录一下. 附上源码:https://gitee.com/niceyoo/jeenotes-ssm 2. 概述 在写代码之前我们先了解一下 ...

  3. Spring+SpringMVC+MyBatis+easyUI整合优化篇(四)单元测试实例

    日常啰嗦 前一篇文章<Spring+SpringMVC+MyBatis+easyUI整合优化篇(三)代码测试>讲了不为和不能两个状态,针对不为,只能自己调整心态了,而对于不能,本文会结合一 ...

  4. Spring+SpringMVC+MyBatis+easyUI整合优化篇(五)结合MockMvc进行服务端的单元测试

    日常啰嗦 承接前一篇文章<Spring+SpringMVC+MyBatis+easyUI整合优化篇(四)单元测试实例>,已经讲解了dao层和service层的单元测试,还有控制器这层也不能 ...

  5. Spring+SpringMVC+MyBatis+easyUI整合优化篇(七)图片上传功能

    日常啰嗦 前一篇文章<Spring+SpringMVC+MyBatis+easyUI整合优化篇(六)easyUI与富文本编辑器UEditor整合>讲了富文本编辑器UEditor的整合与使用 ...

  6. Spring+SpringMVC+MyBatis+easyUI整合优化篇(十三)数据层优化-表规范、索引优化

    本文提要 最近写的几篇文章都是关于数据层优化方面的,这几天也在想还有哪些地方可以优化改进,结合日志和项目代码发现,关于数据层的优化,还是有几个方面可以继续修改的,代码方面,整合了druid数据源也开启 ...

  7. SSM Spring+SpringMVC+mybatis+maven+mysql环境搭建

    SSM Spring+SpringMVC+mybatis+maven环境搭建 1.首先右键点击项目区空白处,选择new->other..在弹出框中输入maven,选择Maven Project. ...

  8. Spring+SpringMVC+MyBatis+easyUI整合优化篇

    优化篇 Spring+SpringMVC+MyBatis+easyUI整合优化篇(一)System.out.print与Log Spring+SpringMVC+MyBatis+easyUI整合优化篇 ...

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

    JAVA SSM框架基础面试题https://blog.csdn.net/qq_39031310/article/details/83050192 SSM(Spring + Springmvc + M ...

  10. SSM(Spring +SpringMVC + Mybatis)框架搭建

    SSM(Spring +SpringMVC + Mybatis)框架的搭建 最近通过学习别人博客发表的SSM搭建Demo,尝试去搭建一个简单的SSMDemo---实现的功能是对用户增删改查的操作 参考 ...

随机推荐

  1. 重写equals为啥需要重写hashCode

    描述 以前一直记得重写equals要把hashCode也要重写了,但是一直也是没有搞明白, 最近在看一些东西,觉得有必要记录一下. 了解一下equals equals是Object类的方法, equa ...

  2. LVS之ipvsadm命令

    目录: 安装 基本描述 用法 命令选项 示例 [安装] 可使用yum安装或者从官网下载安装包源码安装,两种方式皆可 先检查是否已经安装ipvsadm [root@v_machine1 ~]# yum ...

  3. mysql 查询相关命令

    1. 结果集按列展示 mysql  -u用户名  -p密码  -D 数据库名 -e  sql语句 示例:mysql   -uroot  -p123456  -D mysql -e select * f ...

  4. MySQL所谓的脏页和“抖”一下是什么联系?

    在我们平时经常用到的sql更新语句,之前是认为只要sql执行,当前sql的操作会立马执行到服务器磁盘上并返回,但是后来我才知道,事实并非如此,在了解事实之前,首先可能需要先了解什么是redo log, ...

  5. SpringCloud(1)----基于RestTemplate微服务项目

    在写SpringCloud搭建微服务之前,我想先搭建一个不通过springcloud只通过SpringBoot和Mybatis进行模块之间额通讯.然后在此基础上再添加SpringCloud框架. 下面 ...

  6. leetcode30 串联所有单词的子串

    先对words中的单词排列组合,然后对s滑窗操作:部分样例超时,代码如下: class Solution { public: vector<int> findSubstring(strin ...

  7. easyUI之练习

    <%@ page language="java" pageEncoding="UTF-8"%> <!DOCTYPE HTML PUBLIC & ...

  8. IIS 7 实现http跳转https 重定向方法

    官网的域名申请了一个SSL加密,导致原来的http无法访问了,网上找了一下解决方案,https://www.cnblogs.com/wer-ltm/p/10190535.html  按照这个方法进行了 ...

  9. kubernetes/dashboard Getting Started

    Kubernetes Dashboard is a general purpose, web-based UI for Kubernetes clusters. It allows users to ...

  10. liunx基本操作命令

    1.  rm  删除命令 rm   -i  文件名-----------询问y/N 删除文件 rm  -f  文件名-----------直接删除文件 rm  -r  目录 rm   文件名 rm  ...