配置参数解释:
slow_query_log : 是否开启慢查询日志, 1表示开启,0表示关闭。
log-slow-queries: mysql数据库慢查询日志存储路径,系统默认缺省host_name_slow.log。
long_query_time: 慢查询阈值,当查询时间多余设定的阈值,记录日志。
log_queries_not_using_indexes: 未使用索引的查询也被记录到慢查询日志中(可选项)。
log_output: 日志存储方式。log_output='FILE',表示将日志文件存入文件,默认为FILE.log_output='TABLE',表示将日志存入数据库,这样日志信息会存入mysql.slow_log表中。也可以同时记录到表和文件中,记录到专用的日志表比文件要消耗更多的系统资源,建议优先记录到文件。
show variables like '%slow_query_log%'
+---------------------+-----------------------------------------------+
| Variable_name | Value |
+---------------------+-----------------------------------------------+
| slow_query_log | OFF |
| slow_query_log_file | /home/WDPM/MysqlData/mysql/DB-Server-slow.log |
使用set global slow_query_log=1 开启慢查询日志只对当前数据库生效,要永久生效就必须修改配置文件my.cnf
slow_query_log =1
slow_query_log_file=/tmp/mysql_slow.log
mysql> show variables like 'long_query_time%';
+-----------------+-----------+
| Variable_name | Value |
+-----------------+-----------+
| long_query_time | 10.000000 |
+-----------------+-----------+
1 row in set (0.00 sec)
mysql> set global long_query_time=4;
Query OK, 0 rows affected (0.00 sec)
mysql> show variables like 'long_query_time';
+-----------------+-----------+
| Variable_name | Value |
+-----------------+-----------+
| long_query_time | 10.000000 |
+-----------------+-----------+
1 row in set (0.00 sec)
如上所示,我修改了变量long_query_time,但是查询变量long_query_time的值还是10,难道没有修改到呢?注意:使用命令 set global long_query_time=4修改后,需要重新连接或新开一个会话才能看到修改值。你用show variables like 'long_query_time'查看是当前会话的变量值,你也可以不用重新连接会话,而是用show global variables like 'long_query_time';
修改my.cnf
在配置文件my.cnf(一般为/etc/my.cnf)中的[mysqld] 下面增加如下参数。
[mysqld]
#表示开启慢查询,0表示关闭
slow_query_log = 1
#指定慢查询日志路径,需要MySQL对该路径有写权限,不指定用默认也可以
slow_query_log_file = /logs/mysql/slow-query.log
#表示查询时间>=1秒才记录日志,默认10s
long_query_time = 1
#表明记录没有使用索引的 SQL 语句
log_queries_not_using_indexes = 1
重启MySQL服务
sudo systemctl restart mysqld.service
重启MySQL后会看到/var/lib/mysql/slow-query.log文件。
检查参数
$ show variables like 'slow_query_log'
$ show variables like 'slow_query_%'
$ show global slow_query_log_file= '/'
$ show variables like '%log%'
$ show variables like 'long_query_time'
$ show variables like 'slow%'
$ set global log_queries_not_using_indexes=on;
$ set global long_query_time=1;
$ set global slow_query_log=on; //开启慢查询
日志分析工具
在生产环境中,如果手工分析日志、分析SQL,显然是个体力活,Mysql提供了日志分析工具,mysqldumpslow
[root@DB-Server ~]# mysqldumpslow --help
Usage: mysqldumpslow [ OPTS... ] [ LOGS... ]
Parse and summarize the MySQL slow query log. Options are
--verbose verbose
--debug debug
--help write this text to standard output
-v verbose
-d debug
-s ORDER what to sort by (al, at, ar, c, l, r, t), 'at' is default
al: average lock time
ar: average rows sent
at: average query time
c: count
l: lock time
r: rows sent
t: query time
-r reverse the sort order (largest last instead of first)
-t NUM just show the top n queries
-a don't abstract all numbers to N and strings to 'S'
-n NUM abstract numbers with at least n digits within names
-g PATTERN grep: only consider stmts that include this string
-h HOSTNAME hostname of db server for *-slow.log filename (can be wildcard),
default is '*', i.e. match all
-i NAME name of server instance (if using mysql.server startup script)
-l don't subtract lock time from total time
得到返回记录集最多的10个SQL语句
mysqldumpslow -s r -t 10 /database/mysql/mysql06_slow.log
得到按照时间排序的前10条里面含有左连接的查询语句。
mysqldumpslow -s t -t 10 -g “left join” /database/mysql/mysql06_slow.log
获取访问次数最多的5个SQL语句
mysqldumpslow -s c -t 5 /logs/mysql/slow-query.log
按照时间排的top 5个SQL语句
mysqldumpslow -s t -t 5 /logs/mysql/slow-query.log
按照时间排序且含有'like'的top 5个SQL语句
mysqldumpslow -s t -t 3 -g "like" /logs/mysql/slow-query.log
默认情况下,MySQL不启动慢查询日志。若要检查慢查询,需要我们手动设置这个参数。一般情况下,若非调优需要,不建议启动该参数,因为开启慢查询日志或多或少会带来一定的性能影响。慢查询日志支持将日志记录写入文件,也支持将日志记录写入数据库表。
Java实现把图片上传到图片服务器(nginx+vsftp)
//www.greatytc.com/p/67fc9148f95a