mysql中如何使用showprofiles分析sql性能

這篇文章主要介紹了MySQL中如何使用show profiles分析sql性能,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

蘇尼特左網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)建站!從網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、APP開(kāi)發(fā)、響應(yīng)式網(wǎng)站等網(wǎng)站項(xiàng)目制作,到程序開(kāi)發(fā),運(yùn)營(yíng)維護(hù)。創(chuàng)新互聯(lián)建站2013年開(kāi)創(chuàng)至今到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來(lái)保證我們的工作的順利進(jìn)行。專(zhuān)注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)建站。

Show profiles是5.0.37之后添加的,要想使用此功能,要確保版本在5.0.37之后。
 
查看一下我的版本
> Select  version();
+---------------------+
| version()           |
+---------------------+
| 5.0.82-community-nt |
+---------------------+
  www.2cto.com  
1 row in set (0.00 sec)
 
版本是支持show profiles功能的。接下來(lái)進(jìn)入mysql性能跟蹤診斷的世界
 
查看是否打開(kāi)了profiles功能,默認(rèn)是關(guān)閉的
 
mysql> use test;
 
Database changed
 
mysql> show profiles;
 
Empty set (0.00 sec)
 
顯示為空,說(shuō)明profiles功能是關(guān)閉的。下面開(kāi)啟
 
mysql> set profiling=1;
 
Query OK, 0 rows affected (0.00 sec)
 
執(zhí)行下面的查詢(xún)
  www.2cto.com  
mysql> explain select distinct player_idfrom task limit 20;
 
mysql> select distinct player_id from task ;
 
然后執(zhí)行 show profiles
 
mysql> show profiles;
 
+----------+------------+------------------------------------------------------+
 
| Query_ID | Duration   | Query                                               |
 
+----------+------------+------------------------------------------------------+
 
|       1 | 0.00035225 | explain select distinct player_id from task limit 20 |
 
|       2 | 1.91772775 | select distinct player_id from task                  |
 
+----------+------------+------------------------------------------------------+
 
此時(shí)可以看到執(zhí)行select distinct player_id from task 用了1.91772775秒的時(shí)間
 
根據(jù)query_id 查看某個(gè)查詢(xún)的詳細(xì)時(shí)間耗費(fèi)
 
mysql> show profile for query 2;
  www.2cto.com  
+----------------------+----------+
 
| Status               | Duration |
 
+----------------------+----------+
 
| starting             | 0.000052 |
 
| Opening tables       | 0.000009 |
 
| System lock          | 0.000003 |
 
| Table lock           | 0.000007 |
 
| init                 | 0.000013 |
 
| optimizing           | 0.000003 |
 
| statistics           | 0.000009 |
 
| preparing            | 0.000008 |
 
| Creating tmp table   | 0.000074 |
 
| executing            | 0.000002 |
 
| Copying to tmp table |1.916551 |
  www.2cto.com  
| Sending data         | 0.000667 |
 
| end                  | 0.000004 |
 
| removing tmp table   | 0.000065 |
 
| end                  | 0.000002 |
 
| end                  | 0.000002 |
 
| query end            | 0.000003 |
 
| freeing items        | 0.000245 |
 
| closing tables       | 0.000006 |
 
| logging slow query   | 0.000002 |
 
| cleaning up          | 0.000003 |
 
+----------------------+----------+
 
可以看到紅色字體部分耗費(fèi)了大量時(shí)間,這是因?yàn)閐istinct查看會(huì)用到臨時(shí)表
 
那么可不可以查看占用cpu、 io等信息呢
 
 mysql> show profile block io,cpu for query2;
 
+----------------------+----------+----------+------------+--------------+------
 
---------+
 
| Status               | Duration | CPU_user |CPU_system | Block_ops_in | Block
 
_ops_out |
 
+----------------------+----------+----------+------------+--------------+------
  www.2cto.com  
---------+
 
| starting             | 0.000052 |     NULL |       NULL |         NULL |
 
   NULL |
 
| Opening tables       | 0.000009 |     NULL |       NULL |         NULL |
 
   NULL |
 
| System lock          | 0.000003 |     NULL |       NULL |         NULL |
 
   NULL |
 
| Table lock           | 0.000007 |     NULL |       NULL |         NULL |
 
   NULL |
 
| init                 | 0.000013 |     NULL |       NULL |         NULL |
 
   NULL |
 
| optimizing           | 0.000003 |     NULL |       NULL |         NULL |
 
   NULL |
 
| statistics           | 0.000009 |     NULL |       NULL |         NULL |
 
   NULL |  www.2cto.com  
 
| preparing            | 0.000008 |     NULL |       NULL |        NULL |
 
   NULL |
 
| Creating tmp table   | 0.000074 |     NULL |       NULL |         NULL |
 
   NULL |
 
| executing            | 0.000002 |     NULL |       NULL |         NULL |
 
   NULL |
 
| Copying to tmp table | 1.916551 |     NULL |       NULL |        NULL |
 
   NULL |
 
| Sending data         | 0.000667 |     NULL |       NULL |         NULL |
 
   NULL |
 
| end                  | 0.000004 |     NULL |       NULL |         NULL |
 
   NULL |
 
| removing tmp table   | 0.000065 |     NULL |       NULL |         NULL |
 
   NULL |
 
| end                  | 0.000002 |     NULL |       NULL |         NULL |
 
   NULL |
 
| end                  | 0.000002 |     NULL |       NULL |         NULL |
 
   NULL |
 
| query end            | 0.000003 |     NULL |       NULL |         NULL |
 
   NULL |
 
| freeing items        | 0.000245 |     NULL |       NULL |         NULL |
 
   NULL |
 
| closing tables       | 0.000006 |     NULL |       NULL |         NULL |
 
   NULL |
  www.2cto.com  
| logging slow query   | 0.000002 |     NULL |       NULL |         NULL |
 
   NULL |
 
| cleaning up          | 0.000003 |     NULL |       NULL |         NULL |
 
   NULL |
 
+----------------------+----------+----------+------------+--------------+------
另外還可以看到memory,swaps,context switches,source 等信息

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“mysql中如何使用show profiles分析sql性能”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!

文章題目:mysql中如何使用showprofiles分析sql性能
文章源于:http://bm7419.com/article48/gocdep.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供標(biāo)簽優(yōu)化微信小程序、品牌網(wǎng)站建設(shè)、網(wǎng)站策劃做網(wǎng)站、面包屑導(dǎo)航

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁(yè)設(shè)計(jì)