mysql有以下几种日志:
错误 日志: log-err
查询 日志: log
慢查询日志: log-slow-queries
更新 日 志: log-update
二进制日志: log-bin
在mysql的安装目录下,打开my.ini,在后面加上上面的参数,保存后重启mysql服务就行了。
例如:
#Enter a name for the binary log. Otherwise a default name will be used.
#log-bin=
#Enter a name for the query log file. Otherwise a default name will be used.
#log=
#Enter a name for the error log file. Otherwise a default name will be used.
log-error=
#Enter a name for the update log file. Otherwise a default name will be used.
#log-update=
上面只开启了错误日志,要开其他的日志就把前面的“#”去掉
查看命令:
①show variables like 'log_%';查看所有的log命令
②show variables like 'log_bin';查看具体的log命令
================================================
以下是mysqldumpslow常用参数说明,详细的可应用mysqldumpslow -help查询。
-s,是表示按照何种方式排序,
c、t、l、r分别是按照记录次数、时间、查询时间、返回的记录数来排序(从大到小),
ac、at、al、ar表示相应的倒叙。
-t,是top n的意思,即为返回前面多少条数据。
www.2cto.com -g,后边可以写一个正则匹配模式,大小写不敏感。
接下来就是用mysql自带的慢查询工具mysqldumpslow分析了(mysql的bin目录下),我这里的日志文件名字是host-slow.log。
列出记录次数最多的10个sql语句 mysqldumpslow -s c -t 10 host-slow.log
列出返回记录集最多的10个sql语句 mysqldumpslow -s r -t 10 host-slow.log
按照时间返回前10条里面含有左连接的sql语句 mysqldumpslow -s t -t 10 -g "left join" host-slow.log
使用mysqldumpslow命令可以非常明确的得到各种我们需要的查询语句,对MySQL查询语句的监控、分析、优化起到非常大的帮助。
================================================
打开日志:
vim /etc/my.cnf
[mysqld]
log = /var/log/mysqlyy.log //日志
log-slow-queries = /var/log/mysqlowlyy.log //慢查询日志
long_query_time = 1; 操作时间>1秒的都会被记录到mysqlowlyy.log中
log_queries-not-using-indexes //是否显示没有索引的查询
================================================
注意:添加log时候需要手动touch log文件并赋予读写权限 否则不奏效
mysql有以下几种日志:
错误 日志: log-err
查询 日志: log
慢查询日志: log-slow-queries
更新 日 志: log-update
二进制日志: log-bin
在mysql的安装目录下,打开my.ini,在后面加上上面的参数,保存后重启mysql服务就行了。
例如:
#Enter a name for the binary log. Otherwise a default name will be used.
#log-bin=
#Enter a name for the query log file. Otherwise a default name will be used.
#log=
#Enter a name for the error log file. Otherwise a default name will be used.
log-error=
#Enter a name for the update log file. Otherwise a default name will be used.
#log-update=
上面只开启了错误日志,要开其他的日志就把前面的“#”去掉
查看命令:
①show variables like 'log_%';查看所有的log命令
②show variables like 'log_bin';查看具体的log命令
================================================
以下是mysqldumpslow常用参数说明,详细的可应用mysqldumpslow -help查询。
-s,是表示按照何种方式排序,
c、t、l、r分别是按照记录次数、时间、查询时间、返回的记录数来排序(从大到小),
ac、at、al、ar表示相应的倒叙。
-t,是top n的意思,即为返回前面多少条数据。
www.2cto.com -g,后边可以写一个正则匹配模式,大小写不敏感。
接下来就是用mysql自带的慢查询工具mysqldumpslow分析了(mysql的bin目录下),我这里的日志文件名字是host-slow.log。
列出记录次数最多的10个sql语句 mysqldumpslow -s c -t 10 host-slow.log
列出返回记录集最多的10个sql语句 mysqldumpslow -s r -t 10 host-slow.log
按照时间返回前10条里面含有左连接的sql语句 mysqldumpslow -s t -t 10 -g "left join" host-slow.log
使用mysqldumpslow命令可以非常明确的得到各种我们需要的查询语句,对MySQL查询语句的监控、分析、优化起到非常大的帮助。
================================================
打开日志:
vim /etc/my.cnf
[mysqld]
log = /var/log/mysqlyy.log //日志
log-slow-queries = /var/log/mysqlowlyy.log //慢查询日志
long_query_time = 1; 操作时间>1秒的都会被记录到mysqlowlyy.log中
log_queries-not-using-indexes //是否显示没有索引的查询
================================================
注意:添加log时候需要手动touch log文件并赋予读写权限 否则不奏效