冻结库存,性能翻8倍的背后原理

冻结库存,性能翻8倍的背后原理

#技术 #mysql

背景如下

双十一压测,库存服务冻结场景性能 不忍直视,QPS 令人汗颜,相比于其他的接口性能,差的不止一点半点。 sql如下

sql 复制代码
update stockset frozen_num = frozen_num + #{num}where  stock_num - frozen_num  - #{num}> 0and id = #{id}

单数据,循环去压
最终是由DBA从db 的层面,去解决了这个问题。
当时业务侧,通过代码进行压测,单条性能只能达到1000+ 一点 但是dba 单压sql ,能达到1.2 w左右的QPS,这样的情况。

如何会有这么大的一个差别。

解决思路

通过以上的一个表现,去进行了一些思考。

  • 业务侧的路由算法导致

路由一般都是很简单的基本算法,不会有太大的性能损耗,且是倍数的处理。

  • 事务问题导致: 的确,带事务比不带事务,性能要高不少,但是也是有限,依旧达不到DBA的压测水准。
  • 业务侧 + db 侧 两方面处理 目前DB 版本为 mysql 5.7.x 最后调整了这2个参数

这2个基于mysql 5.7 新增的参数设置,通过设置该值,压测性能 也能到达了 8000

但是,究竟原理是为什么呢?

1.: ** binlog_group_commit_sync_delay

全局动态变量,单位微妙,默认0,范围:0~1000000(1秒)。 表示binlog提交后等待延迟多少时间再同步到磁盘,默认0,不延迟。设置延迟可以让多个事务在用一时刻提交,提高binlog组提交的并发数和效率,提高slave的吞吐量。 2: binlog_group_commit_sync_no_delay_count

全局动态变量,单位个数,默认0,范围:0~1000000。

表示等待延迟提交的最大事务数,如果上面参数的时间没到,但事务数到了,则直接同步到磁盘。若 binlog_group_commit_sync_delay 没有开启,则该参数也不会开启。

思考

如果问题发生,如何进行思考?

  1. 表象是这个表象,要通过表象查看事物底层原因问题
  2. 技术底层知识,必不可少,比如 io,mysql底层,往往一些常规的措施,已经知道的,大家都已经知道了,而真正卓越优秀突出的,就在在往前的那么一丁点上。
  3. 多扩展自己的知识面,触类旁通,这样有更高的眼界和思维,更多方面的思考。
  4. 一个人,难以想明白,集合大家的思路,一起进行脑暴
相关推荐
理智的煎蛋4 小时前
MySQL高可用架构:MHA
linux·数据库·mysql·架构·可用性测试
KING BOB!!!7 小时前
Leetcode高频 SQL 50 题(基础版)题目记录
sql·mysql·算法·leetcode
木心爱编程7 小时前
C++容器内存布局与性能优化指南
开发语言·c++·性能优化
我是渣哥7 小时前
Java String vs StringBuilder vs StringBuffer:一个性能优化的探险故事
java·开发语言·jvm·后端·算法·职场和发展·性能优化
工一木子7 小时前
深入Java并发:锁机制原理剖析与性能优化实战
java·性能优化·并发·
Dolphin_Home7 小时前
IT需求提示未读信息查询:深度技术解析与性能优化指南【类似:钉钉已读 功能】
性能优化·钉钉
NineData10 小时前
NineData发布 Oracle 到 MySQL 双向实时复制,助力去 O 战略与数据回流
mysql·阿里云·oracle·ninedata·数据库迁移·数据复制·双向复制
技术小泽11 小时前
深度解析Netty架构工作原理
java·后端·性能优化·架构·系统架构
皆过客,揽星河11 小时前
mysql初学者练习题(从基础到进阶,相关数据sql脚本在最后)
数据库·sql·mysql·oracle·mysql基础练习·mysql基础语法·数据库练习题
AI小小怪13 小时前
在linux下使用MySQL常用的命令集合
linux·数据库·mysql·oracle