在MySQL中,如何定位慢查询?
以下情况会产生:聚合查询、多表查询、表数据量过大查询、深度分页查询
表象:页面加载过慢、接口压测响应时间过长(超过1s)
方案一: 开源工具
调试工具:Arthas
运维工具: Prometheus 、Skywalking
方案二: MySQL自带慢日志
慢查询日志记录了所有执行时间超过指定参数(long query_time,单位:秒,默认10秒)的所有SQL语句的日志如果要开启慢查询日志,需要在MySQL的配置文件(/etc/my.cnf)中配置如下信息:
#开启MySQL慢日志查询开关
slow_query_log=1
#设置慢日志的时间为2秒,SQL语句执行时间超过2秒,就会视为慢查询,记录慢查询日志
long_query_time=2
配置完毕之后,重新启动MySQL服务器进行测试,查看慢日志文件中记录的信息/var/lib/mysql/localhost-slow.log。