昨天试着将最近写的秒杀项目部署到服务器上做压力测试。
在商品详情做压测一点问题没遇上,因为还没做优化所以当时吞吐量300我觉得还ok
然后下单操作的压测就突然一下子请求完全没响应,然后我看cpu性能监控cpu性能爆红,100%
然后立刻停掉项目,发现性能占用很快就下来了,接着去看日志,发现报错出现了lock wait timeout,大致看得懂啥意思,但是不知道怎么解决。
顺着网上各个博主的思路查看发现我想要查询的表从我一开始查询就lock wait,而锁就是我在查询时加的for update排他锁,就很离谱了。
当时咨询老师,老师说我的表结构不合理需要重新改改,改动的时候发现表完全锁死动不了了,于是我就重启了mysql。
重启之后发现for update的语句能跑通了,再次尝试下单操作,但是还是卡在某个位置。debug一遍就发现了是我在生成订单号时的一个循环算法中,判断循环终止的语句应当是取余,而不是相除。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/198887.html