MySQL的cpu使用率100%的問題排查流程
1. 確認CPU占用來源
- 檢查系統(tǒng)進程
使用top或htop命令,確認是否是mysqld進程導致CPU滿載:
top -c -p $(pgrep mysqld)
2. 實時分析MySQL活動
- 查看當前運行的SQL
登錄MySQL,執(zhí)行以下命令,觀察是否有長時間運行或高頻率的查詢:
SHOW FULL PROCESSLIST; -- 或過濾非空閑連接 SELECT * FROM INFORMATION_SCHEMA.PROCESSLIST WHERE COMMAND != 'Sleep' AND TIME > 0;

- 終止問題查詢
若發(fā)現(xiàn)異常查詢,可通過KILL [PROCESS_ID]終止。
3. 分析慢查詢與執(zhí)行計劃
啟用慢查詢日志
在MySQL配置文件(my.cnf/my.ini)中啟用慢查詢日志:
slow_query_log = 1 slow_query_log_file = /var/log/mysql/slow.log long_query_time = 2 -- 閾值(秒)
重啟MySQL后,使用
mysqldumpslow或pt-query-digest分析日志。使用
EXPLAIN分析SQL
對可疑查詢添加EXPLAIN,檢查是否缺少索引或全表掃描:
EXPLAIN SELECT * FROM your_table WHERE your_condition;
4. 檢查索引與表結構
- 索引缺失通過
SHOW CREATE TABLE檢查表結構,確保高頻查詢字段有索引。 - 冗余索引使用
pt-duplicate-key-checker工具刪除無效索引。 - 統(tǒng)計信息過時執(zhí)行
ANALYZE TABLE your_table;更新統(tǒng)計信息。
5. 排查鎖爭用與事務
- 查看當前鎖狀態(tài)
SHOW ENGINE INNODB STATUS; -- 查看LATEST DETECTED DEADLOCK SELECT * FROM INFORMATION_SCHEMA.INNODB_TRX; -- 運行中的事務 SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS; -- 當前持有的鎖
- 長事務處理終止未提交的長事務或優(yōu)化事務代碼。
6. 檢查MySQL配置
- 關鍵參數(shù)調優(yōu)
innodb_buffer_pool_size:建議設置為物理內存的70%-80%。max_connections:避免過高導致資源爭用。tmp_table_size和max_heap_table_size:減少磁盤臨時表。
- 連接數(shù)監(jiān)控
SHOW STATUS LIKE 'Threads_connected'; -- 當前連接數(shù) SHOW VARIABLES LIKE 'max_connections'; -- 最大允許連接數(shù)
7. 系統(tǒng)資源與硬件瓶頸
- 內存與交換分區(qū)使用
free -h或vmstat檢查內存是否不足,導致頻繁Swap。 - 磁盤I/O使用
iostat或iotop查看磁盤負載,優(yōu)化高I/O操作(如批量寫入、索引重建)。 - CPU架構確認是否因并發(fā)線程過多導致CPU爭用(如
innodb_thread_concurrency設置)。
8. 其他可能原因
- 復制問題主從復制延遲或錯誤可能導致從庫CPU升高,檢查
SHOW SLAVE STATUS。 - 緩存失效如查詢緩存(
query_cache_type)頻繁失效,考慮關閉。 - 日志寫入壓力關閉不必要的日志(如通用查詢日志),或調整
sync_binlog參數(shù)。
9. 使用專業(yè)工具
- 監(jiān)控工具Percona Monitoring and Management (PMM)、VividCortex 或 Prometheus + Grafana。
- 性能分析工具
pt-query-digest、mysqlsla或 MySQL自帶的Performance Schema。
快速處理步驟
top確認MySQL進程導致CPU滿載。SHOW PROCESSLIST查找異常查詢。EXPLAIN分析問題SQL,優(yōu)化索引或查詢邏輯。- 終止阻塞進程(
KILL)或重啟MySQL(臨時恢復)。
通過以上步驟,多數(shù)情況下可以定位到CPU過高的根本原因,如慢查詢、索引缺失、配置不當或硬件瓶頸,進而針對性優(yōu)化。若問題復雜,建議結合監(jiān)控工具長期跟蹤分析。
最后
以上就是MySQL的cpu使用率100%的問題排查流程的詳細內容,更多關于MySQL cpu使用率100%的資料請關注腳本之家其它相關文章!
相關文章
mysql使用自定義序列實現(xiàn)row_number功能(步驟詳解)
這篇文章主要介紹了mysql使用自定義序列實現(xiàn)row_number功能,本文分步驟通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下2021-12-12
通過命令行導入到mysql數(shù)據(jù)庫時出現(xiàn)亂碼的解決方法
原因: 含有中文字符的mysql數(shù)據(jù)庫文件,通過命令行導入到mysql數(shù)據(jù)庫中容易出現(xiàn)亂碼。2014-07-07
mysql數(shù)據(jù)庫replace、regexp的用法
mysql數(shù)據(jù)庫中replace、regexp的用法,主要是通過sql語句實現(xiàn)數(shù)據(jù)的替換,使用mysql的朋友可以參考下。2011-08-08
用SELECT... INTO OUTFILE語句導出MySQL數(shù)據(jù)的教程
這篇文章主要介紹了用SELECT... INTO OUTFILE語句導出MySQL數(shù)據(jù)的教程,是MySQL入門學習中的基礎知識,需要的朋友可以參考下2015-05-05

