共計(jì) 3085 個字符,預(yù)計(jì)需要花費(fèi) 8 分鐘才能閱讀完成。
這篇文章主要講解了“MySQL 的慢查詢是什么”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著丸趣 TV 小編的思路慢慢深入,一起來研究和學(xué)習(xí)“MySQL 的慢查詢是什么”吧!
MySQL 慢查詢分析
在我們做系統(tǒng)性能調(diào)優(yōu)的時候,數(shù)據(jù)庫的慢查詢語句的優(yōu)化是必不可少的,特別是電子商務(wù)類型的重度 MYSQL 應(yīng)用類型。
下面我們一起來看看怎么做好 MYSQL 的慢查詢分析吧。
1,開啟 MYSQL 的慢查詢?nèi)罩?
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 的都認(rèn)為是慢查詢
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,如果看到有記錄就表示設(shè)置成功了。不過,生成慢查詢?nèi)罩局皇侵覍?shí)的 記錄了每一條慢查詢,對于我們做分析并不方便。
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
# 其實(shí)是一個 perl 腳本
#/usr/local/bin/mysqlsla: a /usr/bin/perl -w script text executable
3,慢查詢統(tǒng)計(jì)
# 統(tǒng)計(jì)出現(xiàn)次數(shù)最多的前 10 條慢查詢
mysqlsla -lt slow /var/log/mysql-slow .log – top 10 – sort c_sum top10_count_sum.log
# 統(tǒng)計(jì)執(zhí)行時間的總和前 10 條慢查詢
mysqlsla -lt slow /var/log/mysql-slow .log – top 10 – sort t_sum top10_time_sum.log
# 統(tǒng)計(jì)平均執(zhí)行時間最長的前 10 條慢查詢(常用)
mysqlsla -lt slow /var/log/mysql-slow .log – top 10 – sort t_avg top10_time_avg.log
打開其中一個 log 統(tǒng)計(jì)文件,你會看到:
www.2cto.com
Report for slow logs: /var/log/mysql-slow.log 被分析的慢查詢?nèi)罩疚募?
40 queries total, 12 unique 40 條查詢;除了重復(fù)的,有 12 條查詢
Sorted by lsquo;t_avg rsquo; 按平均查詢時間排序
Grand Totals: Time 4 s, Lock 0 s, Rows sent 236, Rows Examined 8.63k
______________________________________________________________________ 001 ___
Count : 1 (2.50%)這條 SQL 出現(xiàn)了 1 次,占 SQL 總數(shù)的 2.5%
Time : 588.994 ms total 執(zhí)行時間總和, 588.994 ms avg 平均每次查詢的時間, 588.994 ms 最短時間 to 588.994 ms max 最長時間 (13.78%)
Lock Time (s) : 91 micro;s total, 91 micro;s avg, 91 micro;s to 91 micro;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 lsquo;S rsquo; ORDER BY ecm_goods.brand_id ASC LIMIT N, N;
Query sample:
SET timestamp=1341467496;
SELECT * FROM `ecm_goods` WHERE goods_name like lsquo; 冰箱 rsquo; ORDER BY `ecm_goods`.`brand_id` ASC
LIMIT 0, 30;
______________________________________________________________________ 002 ___
Count : 2 (5.00%) 這條 SQL 出現(xiàn)了 2 次,占 SQL 總數(shù)的 5%
Time : 57.38 ms total 執(zhí)行時間總和, 28.69 ms avg 平均每次查詢的時間, 27.503 ms 最短時間 to 29.877 ms max 最長時間 (1.34%)
Lock Time (s) : 134 micro;s total, 67 micro;s avg, 64 micro;s to 70 micro;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;
hellip; 其他省略 hellip;
如果需要做更復(fù)雜的統(tǒng)計(jì),可以參考官方文檔:http://hackmysql.com/mysqlsla_guide
如果希望每隔一段時間,比如一天,出一次慢查詢統(tǒng)計(jì)的話,可以寫一個 shell 腳本,然后放到 /etc/crontab 里面。這樣的話,就可以定期做查詢優(yōu)化。
感謝各位的閱讀,以上就是“MySQL 的慢查詢是什么”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對 MySQL 的慢查詢是什么這一問題有了更深刻的體會,具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是丸趣 TV,丸趣 TV 小編將為大家推送更多相關(guān)知識點(diǎn)的文章,歡迎關(guān)注!