我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL的慢查询是什么

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL的慢查询是什么

这篇文章主要讲解了“MySQL的慢查询是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL的慢查询是什么”吧!

MySQL慢查询分析
 
在我们做系统性能调优的时候,数据库的慢查询语句的优化是必不可少的,特别是电子商务类型的重度MYSQL应用类型。
下面我们一起来看看怎么做好MYSQL的慢查询分析吧。
1,开启MYSQL的慢查询日志
  www.2cto.com  
首先在my.cnf配置里面加入慢查询配置,然后建立慢查询的日志文件,并把用户和组修改为mysql,最后重启mysqld。
 
vim /etc/my .cnf
# 在配置文件的[mysqld]下面加入以下几行
log-slow-queries= /var/log/mysql-slow .log
long_query_time=0.01 #表示查询时间超过10ms的都认为是慢查询
log-queries-not-using-indexes #表示没有使用索引的查询也记录日志
 
touch /var/log/mysql-slow .log
chown mysql.mysql /var/log/mysql-slow .log
/etc/init .d /mysqld restart
接着测试一下慢查询是否生效,可以访问一下myadmin或者跑一条select sleep(1),然后再cat一下/var/log/-slow.log,如果看到有记录就表示设置成功了。不过,生成慢查询日志只是忠实的 记录了每一条慢查询,对于我们做分析并不方便。
 
2,安装mysqlsla慢查询分析工具
wget http: //hackmysql .com /scripts/mysqlsla-2 .03. tar .gz
tar xzf mysqlsla-2.03. tar .gz
cd mysqlsla-2.03
   www.2cto.com  
perl Makefile.PL
make
make install
#安装信息
#Installing /usr/local/share/perl5/mysqlsla.pm
#Installing /usr/local/share/man/man3/mysqlsla.3pm
#Installing /usr/local/bin/mysqlsla
#Appending installation info to /usr/lib/perl5/perllocal.pod
 
file /usr/local/bin/mysqlsla
#其实是一个perl脚本
#/usr/local/bin/mysqlsla: a /usr/bin/perl -w script text executable
3,慢查询统计
 
#统计出现次数最多的前10条慢查询
mysqlsla -lt slow /var/log/mysql-slow .log - top 10 - sort c_sum > top10_count_sum.log
#统计执行时间的总和前10条慢查询
mysqlsla -lt slow /var/log/mysql-slow .log - top 10 - sort t_sum > top10_time_sum.log
#统计平均执行时间最长的前10条慢查询(常用)
mysqlsla -lt slow /var/log/mysql-slow .log - top 10 - sort t_avg > top10_time_avg.log
打开其中一个log统计文件,你会看到:
  www.2cto.com  
Report for slow logs: /var/log/mysql-slow.log 被分析的慢查询日志文件 
40 queries total, 12 unique 40条查询;除了重复的,有12条查询 
Sorted by ‘t_avg’ 按平均查询时间排序 
Grand Totals: Time 4 s, Lock 0 s, Rows sent 236, Rows Examined 8.63k
______________________________________________________________________ 001 ___
Count : 1 (2.50%)这条SQL出现了1次,占SQL总数的2.5%
Time : 588.994 ms total执行时间总和, 588.994 ms avg平均每次查询的时间, 588.994 ms最短时间 to 588.994 ms max最长时间 (13.78%)
Lock Time (s) : 91 µs total, 91 µs avg, 91 µs to 91 µs max (2.34%)
Rows sent : 30 avg, 30 to 30 max (12.71%)
Rows examined : 899 avg, 899 to 899 max (10.41%)
Database :
Users :
coreseektest@localhost : 100.00% (1) of query, 100.00% (40) of all users
 
Query abstract:
SET timestamp=N; SELECT * FROM ecm_goods WHERE goods_name LIKE ‘S’ ORDER BY ecm_goods.brand_id ASC LIMIT N, N;
 
Query sample:
SET timestamp=1341467496;
SELECT * FROM `ecm_goods` WHERE goods_name like ‘冰箱’ ORDER BY `ecm_goods`.`brand_id` ASC
LIMIT 0, 30;
______________________________________________________________________ 002 ___
Count : 2 (5.00%) 这条SQL出现了2次,占SQL总数的5%
Time : 57.38 ms total 执行时间总和, 28.69 ms avg 平均每次查询的时间, 27.503 ms 最短时间 to 29.877 ms max 最长时间 (1.34%)
Lock Time (s) : 134 µs total, 67 µs avg, 64 µs to 70 µs max (3.44%)
Rows sent : 3 avg, 3 to 3 max (2.54%)
Rows examined : 3 avg, 3 to 3 max (0.07%)
Database :
Users :  www.2cto.com  
coreseektest@localhost : 100.00% (2) of query, 100.00% (40) of all usersQuery abstract:
SET timestamp=N; SELECT * FROM documents LIMIT N, N;
Query sample:
SET timestamp=1341399487;
SELECT * FROM `documents` LIMIT 0, 30;
 
…其他省略…
 
如果需要做更复杂的统计,可以参考官方文档:http://hackmysql.com/mysqlsla_guide
如果希望每隔一段时间,比如一天,出一次慢查询统计的话,可以写一个shell脚本,然后放到/etc/crontab里面。这样的话,就可以定期做查询优化。

感谢各位的阅读,以上就是“MySQL的慢查询是什么”的内容了,经过本文的学习后,相信大家对MySQL的慢查询是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL的慢查询是什么

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

php mysql 慢查询是什么

php mysql慢查询是指在日志中记录运行比较慢的SQL语句,而开启慢查询日志,可以让MySQL记录下查询超过指定时间的语句,通过定位分析性能的瓶颈,才能更好的优化数据库系统的性能。
2017-06-06

php mysql慢查询是什么意思

这篇文章主要为大家展示了“php mysql慢查询是什么意思”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“php mysql慢查询是什么意思”这篇文章吧。php mysql慢查询是指在日志中记录
2023-06-25

mysql中慢查询日志指的是什么

这篇文章给大家分享的是有关mysql中慢查询日志指的是什么的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1、介绍用于记录执行时间超过某个临界值的SQL日志,用于快速定位慢速查询,供我们优化参考。2、开启方法打开慢
2023-06-15

mysql慢查询优化的方法是什么

MySQL慢查询优化的方法有以下几种:1. 使用索引:索引可以大大提高查询的速度。需要根据查询语句的特点选择合适的列进行索引,避免全表扫描。2. 优化查询语句:通过分析慢查询日志,找到耗时较长的查询语句,进行优化。可以通过修改查询语句的结构
2023-08-31

mysql慢日志查询的方法是什么

要查询MySQL慢日志,可以使用以下方法:登录到MySQL数据库管理系统。运行以下SQL查询语句来查看慢查询日志的参数设置:SHOW VARIABLES LIKE 'slow_query_log';SHOW VARIA
mysql慢日志查询的方法是什么
2024-03-14

MySQL中的慢查询是什么及有哪些危害

本文小编为大家详细介绍“MySQL中的慢查询是什么及有哪些危害”,内容详细,步骤清晰,细节处理妥当,希望这篇“MySQL中的慢查询是什么及有哪些危害”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、什么是慢查询什
2023-07-04

为什么MySQL查询速度会慢

目录一、先了解一下mysql查询的执行过程二、是否查询了不需要的数据三、衡量查询开销的几个重要指标1、响应时间2、扫描的行数和返回的行数3、扫描的行数和访问类型4、一般可以通过explain的Extra列查看查询的优劣一、先了解一下MySQ
2022-12-01

mysql 慢查询排查

-- 查询运行的线程 select * from information_schema.`PROCESSLIST` where info is not null; show full PROCESSLIST; -- 查询所有运行的事务 select * fro
mysql 慢查询排查
2020-07-17

编程热搜

目录