问题
在性能测试过程中,发现MySQL数据库数据没有更新,查看日志发现如下报错
第一反应是代码问题导致死锁,一直占用数据库连接没有释放,用jstack查看进程信息,发现所有线程都正常运行,并没有处于BLOCKED状态,由此可见应该是MySQL层面的锁导致了这个问题。
原因
- 发生问题的表会有多个输入端进行insert和update
- 该表配置了包含一个字段的索引,而这个单列索引非常容易命中,所以会在不同的输入端非常容易锁住同一行
- 命中索引的数据较多,需要请求大量锁资源,导致速度慢
解决方案
去掉该表的单列索引,只保留查询所需的相关索引即可
参考链接