慢查询日志
默认情况下,MySQL数据库没有开启慢查询日志,如果不是调优需要的话,一般不建议启动该参数,因为开启慢查询日志会或多或少带来一定的性能影响。
- 开启慢查询日志
mysql> SHOW VARIABLES LIKE '%slow_query_log%';
mysql> SET GLOBAL slow_query_log = 1;
- 查看慢查询日志
[root@yangjjhost03 ~]# tail -500f /var/lib/mysql/yangjjhost03-slow.log - 查询时间,多少秒之前的为慢查询
mysql> SHOW VARIABLES LIKE '%long_query_time%';
- 修改时间阈值
mysql> SET long_query_time = 5;
mysqldumpslow
日志分析工具 mysqldumpslow
- 常用命令
得到返回记录集最多的10个SQL
[root@yangjjhost03 ~]# mysqldumpslow -s r -t 10 /var/lib/mysql/yangjjhost03-slow.log - 得到访问次数最多的10个SQL
[root@yangjjhost03 ~]# mysqldumpslow -s c -t 10 /var/lib/mysql/yangjjhost03-slow.log - 得到按照时间排序的前10条里面含有关键字的查询语句
[root@yangjjhost03 ~]# mysqldumpslow -s t -t 10 -g “tbl_emp” /var/lib/mysql/yangjjhost03-slow.log | more
profiling
可以用来分析当前会话中语句执行的资源消耗情況。可以用于SQL的调优的测量
默认情況下,参数处于关闭状态,并保存最近15次的运行结果
mysql> SHOW VARIABLES LIKE 'profiling';
- 开启profiling
mysql> SET profiling = 1;
- 查看一个执行计划的总执行时间
mysql> show profiles;
- 具体分析一个执行计划中,SQL语句执行过程中的资源消耗情况
show profile cpu, block io for query n(n为Query_ID)
mysql> show profile cpu, block io for query 4;
converting HEAP to MyISAM 查询结果太大,内存数据写到磁盘
Creating tmp table 拷贝数据到临时表,用完再删除
Copying to tmp table on disk 内存中临时表数据写到磁盘
locked
这四项最耗时耗资源
- 其它可选参数
通用日志
不建议生产环境开启
mysql> SHOW VARIABLES LIKE'%general_log%';
- 开启通用查询日志
mysql> SET GLOBAL general_log = 1;
- 不希望日志输出到文件,希望输出到表中查看
mysql> SET GLOBAL log_output = 'TABLE';
mysql> SHOW VARIABLES LIKE'%log_output%';
- 查看输出
mysql> SELECT * FROM mysql.general_log;