mysql查看當前正在運行的任務_MySQL運行時監測


本文記錄一些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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM