01. 性能分析
MySQL 性能分析
性能瓶颈定位
存储占用分析
-- 统计表、索引 大小
SELECT ISS.SCHEMA_NAME AS "Schema_Name",
ITS.TABLE_NAME AS "Table_Name",
(ITS.DATA_LENGTH / 1024 / 1024) AS "Data(MB)",
(ITS.INDEX_LENGTH / 1024 / 1024) AS "Index(MB)",
((ITS.DATA_LENGTH + ITS.INDEX_LENGTH) / 1024 / 1024) AS "Data+Index(MB)",
ITS.TABLE_ROWS AS "Total_Rows"
FROM `information_schema`.`TABLES` ITS RIGHT JOIN
`information_schema`.`SCHEMATA` ISS
ON ITS.TABLE_SCHEMA = ISS.SCHEMA_NAME
WHERE ISS.SCHEMA_NAME LIKE "x%"
ORDER BY 4 DESC, ISS.SCHEMA_NAME, ITS.TABLE_NAME;
Show
我们可以通过
Mysql> show status ——显示状态信息(扩展show status like 'XXX')
Mysql> show variables ——显示系统变量(扩展show variables like 'XXX')
Mysql> show innodb status ——显示InnoDB存储引擎的状态
Mysql> show processlist ——查看当前SQL执行,包括执行状态、是否锁表等
Shell> mysqladmin variables -u username -p password——显示系统变量
Shell> mysqladmin extended-status -u username -p password——显示状态信息
查看状态变量及帮助:
Shell> mysqld --verbose --help [|more #逐行显示]
慢查询日志
日志开启
在配置文件
log-slow-queries=/data/mysqldata/slow-query.log
long_query_time=2
log-slow-queries=/data/mysqldata/slow-query.log
long_query_time=10
log-queries-not-using-indexes
我们可以通过命令行设置变量来即时启动慢日志查询。由下图可知慢日志没有打开,

设置慢日志开启


为了方便测试,可以将修改慢查询时间为

日志分析
我们可以通过打开
[root@localhost mysql]# more slow-query.log
# Time: 081026 19:46:34
# User@Host: root[root] @ localhost []
# Query_time: 11 Lock_time: 0 Rows_sent: 1 Rows_examined: 6552961
select count(*) from t_user;
从日志中,可以发现查询时间超过
[root@mysql_data]#mysqldumpslow slow-query.log
Reading mysql slow query log from slow-query.log
Count: 2 Time=11.00s (22s) Lock=0.00s (0s) Rows=1.0 (2), root[root]@mysql
select count(N) from t_user;
/path/mysqldumpslow -s c -t 10 /database/mysql/slow-query.log
这会输出记录次数最多的
-s, 是表示按照何种方式排序,c、t、l、r 分别是按照记录次数、时间、查询时间、返回的记录数来排序,ac、at、al、ar,表示相应的倒叙;-t, 是top n 的意思,即为返回前面多少条的数据;-g, 后边可以写一个正则匹配模式,大小写不敏感的; 例如:
/path/mysqldumpslow -s r -t 10 /database/mysql/slow-log
得到返回记录集最多的
/path/mysqldumpslow -s t -t 10 -g “left join” /database/mysql/slow-log
得到按照时间排序的前