本文記錄一些MySQL運行時狀態的命令和方法,用於優化MySQL查詢等。
查看當前查詢任務
基本用法
使用命令:show processlist;可以查看當前系統運行的查詢任務,執行結果如下:
mysql> show processlist;
+-----+------+-----------+----------+---------+------+-------+------------------+
| Id | User | Host | db | Command | Time | State | Info |
+-----+------+-----------+----------+---------+------+-------+------------------+
| 671 | root | localhost | snapchat | Query | 0 | NULL | show processlist |
+-----+------+-----------+----------+---------+------+-------+------------------+
其中各自的的含義如下:
Id任務唯一id
User執行該任務的用戶
Host執行該任務的連接主機
db該任務使用的數據庫
Command當前任務類型,如查詢,寫入臨時表等
Time該任務執行開始到現在的時間
State該任務的專題
Info該任務的附加信息:SQL語句等
state狀態值
state這一列表示當前查詢的狀態,大部分狀態對應很快的操作,只要有一個線程保持同一個狀態好幾秒鍾,那么可能是有問題發生了,需要檢查一下。一些常見值如下:
Checking table: 正在檢查數據表。
Closing tables: 正在將表中修改的數據刷新到磁盤中,同時正在關閉已經用完的表。這是一個很快的操作,如果不是這樣的話,就應該確認磁盤空間是否已經滿了或者磁盤是否正處於重負中
Connect Out: 復制從服務器正在連接主服務器
Copying to tmp table on disk: 由於臨時結果集大於tmp_table_size,正在將臨時表從內存存儲轉為磁盤存儲以此節省內存
Creating tmp table: 正在創建臨時表以存放部分查詢結果
deleting from main table: 正在執行多表刪除中的第一部分,剛刪除第一個表
deleting from reference tables: 正在執行多表刪除中的第二部分,正在刪除其他表的記錄
Flushing tables: 正在執行FLUSH TABLES,等待其他線程關閉數據表
Killed: 發送了一個kill請求給某線程,那么這個線程將會檢查kill標志位,同時會放棄下一個kill請求。MySQL會在每次的主循環中檢查kill標志位,不過有些情況下該線程可能會過一小段才能死掉。如果該線程程被其他線程鎖住了,那么kill請求會在鎖釋放時馬上生效
Locked: 被其他查詢鎖住了
Sending data: 正在處理SELECT查詢的記錄,同時正在把結果發送給客戶端
Sorting for group: 正在為GROUP BY做排序
Sorting for order: 正在為ORDER BY做排序
Opening tables: 這個過程應該會很快,除非受到其他因素的干擾。例如,在執ALTER TABLE或LOCK TABLE語句行完以前,數據表無法被其他線程打開。正嘗試打開一個表
Removing duplicates: 正在執行一個SELECT DISTINCT方式的查詢,但是MySQL無法在前一個階段優化掉那些重復的記錄。因此,MySQL需要再次去掉重復的記錄,然后再把結果發送給客戶端
Reopen table: 獲得了對一個表的鎖,但是必須在表結構修改之后才能獲得這個鎖。已經釋放鎖,關閉數據表,正嘗試重新打開數據表。
Repair by sorting: 修復指令正在排序以創建索引。
Repair with keycache: 修復指令正在利用索引緩存一個一個地創建新索引。它會比Repair by sorting慢些。
Searching rows for update: 正在講符合條件的記錄找出來以備更新。它必須在UPDATE要修改相關的記錄之前就完成了。
Sleeping: 正在等待客戶端發送新請求.
System lock: 正在等待取得一個外部的系統鎖。如果當前沒有運行多個mysqld服務器同時請求同一個表,那么可以通過增加–skip-external-locking參數來禁止外部系統鎖。
Upgrading lock: INSERT DELAYED正在嘗試取得一個鎖表以插入新記錄。
Updating: 正在搜索匹配的記錄,並且修改它們。
User Lock: 正在等待GET_LOCK()。
Waiting for tables: 該線程得到通知,數據表結構已經被修改了,需要重新打開數據表以取得新的結構。然后,為了能的重新打開數據表,必須等到所有其他線程關閉這個表。以下幾種情況下會產生這個通知:FLUSH TABLES tbl_name, ALTER TABLE, RENAME TABLE, REPAIR TABLE, ANALYZE TABLE,或OPTIMIZE TABLE。
waiting for handler insert: INSERT DELAYED已經處理完了所有待處理的插入操作,正在等待新的請求。
結束查詢任務
在使用show processlist顯示的所有連接實例中,如果某個鏈接查詢很慢,耗時很久,可以選擇強制結束。
每一個連接mysqld的實例都在不同線程中執行,直接結束掉線程即可。
KILL [CONNECTION | QUERY] processlist_id
比如下面的例子,使用show processlist顯示的連接實例,看id是多少,直接kill即可:
SHOW FULL PROCESSLIST\G
*************************** 1. row ***************************
Id: 3423
User: system user
Host:
db: NULL
Command: Connect
Time: 1030455
State: Waiting for master to send event
Info: NULL
# 直接kill
kill 3423
————————————————
版權聲明:本文為CSDN博主「weixin_39627144」的原創文章,遵循CC 4.0 BY-SA版權協議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/weixin_39627144/article/details/114349265
