mysql数据库,slowsql慢查询导致接口超时问题
现象:日志中有slowsql,在数据库中执行也查询不出来,接口超时加载不出来。多表关联查询,有索引但在生产环境没用上。
分析过程:
1.查看执行计划, explain。在开发环境时间很快,在生产环境超时,索引失效。关联查询,有几张表10万级数据量,join取笛卡尔集,查询的数据量很大。
2.优化了sql,开发环境从10秒左右优化到0.几秒。生产环境还是超时。
3.由于没有其他报错日志,还是怀疑数据库端的问题。因为各个环境一致的。首先排除数据库版本问题。
4.排查是否锁表了,show OPEN TABLES where In_use>0。如果有,见5
5.查询进程,show processlist。查询到被锁的进程后kill掉
原因:
关联查询的索引,字符集和排序字符集不一致,导致索引失效。
本文深入分析了一起由慢查询导致的接口超时问题,通过对比开发与生产环境,揭示了索引失效的原因,并分享了优化SQL及解决锁表问题的具体步骤。
4098

被折叠的 条评论
为什么被折叠?



