博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MyBatis的Batch处理导致秒杀系统超卖的问题
阅读量:7025 次
发布时间:2019-06-28

本文共 631 字,大约阅读时间需要 2 分钟。

  hot3.png

#1 问题描述# 2015-08-14 周五,线上乐购做活动,1元秒杀大闸蟹,库存设置为10 ,结果卖出去15个,并且线上存在脏数据,有些关联表数据不全。

执行原理:乐购调用订单平台下单,在订单平台调用促销逻辑,在促销逻辑中加限购逻辑。 #2 排查过程#

  1. 走查乐购秒杀的业务代码实现,在高并发的情况下,不会出现线程安全问题;【正常】
  2. 理解业务执行过程中,事务调用流程:Spring事务=>MyBatis事务=>druid事务(数据源)=>DB事务(数据库);【MyBatis的Batch处理导致上层Spring事务失效】
  3. 查看mysql binlog日志,如下:【不正常】

输入图片说明

发现多个事务被合并成了一个事务执行,合并事务之后有啥问题?当合并事务之后,其中有一个事务执行失败后,上层的Spring就无法得知要回滚具体的哪一个事务。 4. MyBatis的配置文件中,SqlSessionTemplate配置存在问题:【不正常】

输入图片说明

#3 解决问题#

  1. 注释掉SqlSessionTemplate中BATCH的配置:

输入图片说明

#4 问题总结# Mybatis内置的ExecutorType有3种,默认的是simple,该模式下它为每个语句的执行创建一个新的预处理语句,单条提交sql;而batch模式重复使用已经预处理的语句,batch模式如果和原spring事务一起使用,将无法回滚。

转载于:https://my.oschina.net/xianggao/blog/530541

你可能感兴趣的文章
关于在多个UItextield切换焦点
查看>>
hdu 2768
查看>>
git记住用户名密码
查看>>
ElasticSearch(2)-安装ElasticSearch
查看>>
从mysql数据表中随机取出一条记录
查看>>
ORACLE 锁表处理,解锁释放session
查看>>
深海机器人问题
查看>>
ios开发之 -- invalid nib registered for identifier
查看>>
正则表达式(括号)、[中括号]、{大括号}的区别小结
查看>>
88.NODE.JS加密模块CRYPTO常用方法介绍
查看>>
java.net.ProtocolException: Exceeded stated content-length of: '13824' bytes
查看>>
asp.net 连接 oracle10g 数据库
查看>>
C 入门 第十一节
查看>>
HTML简单的注册页面搭建
查看>>
【06】Vue 之 组件化开发
查看>>
Docker 安装
查看>>
多数据库数据导入
查看>>
[AVR]高压并行编程---基础知识
查看>>
inl文件介绍
查看>>
前端坑--表单篇
查看>>