亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL的慢查詢是什么

發布時間:2021-08-17 02:43:03 來源:億速云 閱讀:163 作者:chen 欄目:數據庫

這篇文章主要講解了“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的慢查詢是什么這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

韶关市| 定西市| 延庆县| 枣庄市| 南昌市| 顺平县| 托里县| 宜川县| 沅江市| 清水河县| 黑水县| 衡阳市| 时尚| 西乌| 康定县| 武山县| 稷山县| 绩溪县| 英德市| 手游| 尼木县| 普定县| 紫云| 平度市| 浦县| 洛扎县| 古浪县| 潢川县| 五家渠市| 眉山市| 璧山县| 沛县| 横山县| 开平市| 扬州市| 东丰县| 米林县| 定结县| 安远县| 澄江县| 屯昌县|