首页 / 数据库 / MySQL / mysql性能的检查和调优方法
mysql性能的检查和调优方法2011-11-08我一直是使用mysql这个数据库软件,它工作比较稳定,效率也很高。在遇到严重性能问题时,一般都有这么几种可能:1、索引没有建好;2、sql写法过于复杂;3、配置错误;4、机器实在负荷不了;1、索引没有建好如果看到mysql消耗的cpu很大,可以用mysql的client工具来检查。在linux下执行/usr/local/mysql/bin/mysql -hlocalhost -uroot -p输入密码,如果没有密码,则不用-p参数就可以进到客户端界面中。看看当前的运行情况show full processlist可以多运行几次这个命令可以看到当前正在执行的sql语句,它会告知执行的sql、数据库名、执行的状态、来自的客户端ip、所使用的帐号、运行时间等信息在我的cache后端,这里面大部分时间是看不到显示任何sql语句的,我认为这样才算比较正常。如果看到有很多sql语句,那么这台mysql就一定会有性能问题如果出现了性能问题,则可以进行分析:1、是不是有sql语句卡住了?这是出现比较多的情况,如果数据库是采用myisam,那么有可能有一个写入的线程会把数据表给锁定了,如果这条语句不结束,则其它语句也无法运行。查看processlist里的time这一项,看看有没有执行时间很长的语句,要留意这些语句。2、大量相同的sql语句正在执行如果出现这种情况,则有可能是该sql语句执行的效率低下,同样要留意这些语句。然后把你所怀疑的语句统统集合一下,用desc(explain)来检查这些语句。首先看看一个正常的desc输出:mysql> desc select * from imgs where imgid=1651768337;+----+-------------+-------+-------+---------------+---------+---------+-------+------+-------+| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |+----+-------------+-------+-------+---------------+---------+---------+-------+------+-------+| 1 | SIMPLE | imgs | const | PRIMARY | PRIMARY | 8 | const | 1 | |+----+-------------+-------+-------+---------------+---------+---------+-------+------+-------+1 row in set (0.00 sec)