MySQL中如何快速定位占用CPU過高的SQL

作為DBA工作中都會遇到過數據庫服務器CPU飆升的場景,我們該如何快速定位問題?又該如何快速找到具體是哪個SQL引發的CPU異常呢?下面我們說兩個方法。聊聊MySQL中如何快速定位占用CPU過高的SQL。

技術人人都可以磨煉,但處理問題的思路和角度各有不同,希望這篇文章可以拋磚引玉。

以一個例子為切入點

基礎環境:

  • 主機類型:阿里云?
  • 操作系統:CentOS release 7.4
  • 存儲:Alibaba Cloud ECS ???
  • 內存:64 G
  • CPU型號:Intel(R) Xeon(R) Platinum 8163 CPU @ 2.50GHz ( 1 U * 8 core)?
  • CPU核數:16CORE
  • 數據庫環境:MySQL5.7.27
  • 存儲引擎:InnoDB

問題現象:

數據庫服務器CPU飆升。

方案一、通過pidstat命令定位

?

首先我們先找到mysqld進程的PID,然后執行pidstat -t -p $PID,結果如下圖:

進入mysql交互命令,通過以下命令查詢具體SQL。

?select?*?from?performance_schema.threads?where?thread_os_id?=?'1';

定位到了具體定位sql接下來就可以分析優化了。

方案二、通過TOP命令定位

  • 首先執行TOP命令,輸入H,可以按照顯示線程狀態。
  • 輸入P,可以按照cpu的使用時間份額進行排序,這時候我們就可以看下是否有超過70%-90%以上的線程了。


?



登錄mysql,執行以下命令

select?*?from?performance_schema.threads?where?THREAD_OS_ID=4461?\G

 

更多精彩內容,關注我們▼▼

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/536807.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/536807.shtml
英文地址,請注明出處:http://en.pswp.cn/news/536807.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

華為OD機試 - 多段線數據壓縮(Java JS Python C)

在線OJ刷題 題目詳情 - 多段線數據壓縮 - Hydro 題目描述 下圖中,每個方塊代表一個像素,每個像素用其行號和列號表示。 為簡化處理,多線段的走向只能是水平、豎直、斜向45度。 上圖中的多線段可以用下面的坐標串表示:(2,8),(3,7),(3,6),(3,5),(4,4),(5,3),(6,2),(7,3),(…

042、序列模型

之——從時序中獲取信息 目錄 之——從時序中獲取信息 雜談 正文 1.建模 2.方案A-馬爾科夫假設 3.方案B-潛變量模型 4.簡單實現 雜談 很多連續的數據都是有前后的時間相關性的,并不是每一個單獨的數據是隨機出現的。在時序中會蘊含一些空間結構的變化信息、…

【數據科學】一文徹底理清數據、數據類型、數據結構的概念

一、什么是數據? 入門數據學科,首先第一步要認識數據什么,可能大多數人都無法對數據做一個準確的定義,在我們印象中,提到數據首先頭腦浮現的是數據表格,是一堆堆數字,那么數據就是數字嗎&#x…

SpringBoot 2.0 中默認 HikariCP 數據庫連接池原理解析

作為后臺服務開發,在日常工作中我們天天都在跟數據庫打交道,一直在進行各種CRUD操作,都會使用到數據庫連接池。按照發展歷程,業界知名的數據庫連接池有以下幾種:c3p0、DBCP、Tomcat JDBC Connection Pool、Druid 等&am…

阿里云服務器記錄

阿里云服務器記錄 CentOS 8.4 64位 SCC版 CentOS 7.9 64位 SCC版 CentOS 7.9 64位 CentOS 7.9 64位 UEFI版 Alibaba Cloud Linux Anolis OS CentOS Windows Server Ubuntu Debian Fedora OpenSUSE Rocky Linux CentOS Stream AlmaLinux 阿里云服務器有個scc版,這個…

Flask+Mysql項目docker-compose部署(Pythondocker-compose詳細步驟)

一、前言 環境: Linux、docker、docker-compose、python(Flask)、Mysql 簡介: 簡單使用Flask框架寫的查詢Mysql數據接口,使用docker部署,shell腳本啟動 優勢: 采用docker方式部署更加便于維護,更加簡單快…

如何在Go中使用模板

引言 您是否需要以格式良好的輸出、文本報告或HTML頁面呈現一些數據?你可以使用Go模板來做到這一點。任何Go程序都可以使用text/template或html/template包(兩者都包含在Go標準庫中)來整齊地顯示數據。 這兩個包都允許你編寫文本模板并將數據傳遞給它們,以按你喜歡的格式呈…

“C語言“——scanf()、getchar() 、putchar()、之間的關系

scanf函數說明 scanf函數是對來自于標準輸入流的輸入數據作格式轉換,并將轉換結果保存至format后面的實參所指向的對象。 而const char*format 指向的字符串為格式控制字符串,它指定了可輸入的字符串以及賦值時轉換方法。 簡單來說給一個打印格式(輸入…

【并發編程篇】源碼分析,手動創建線程池

文章目錄 🛸前言🌹Executors的三大方法 🍔簡述線程池🎆手動創建線程池?源碼分析?代碼實現,手動創建線程池🎈CallerRunsPolicy()🎈AbortPolicy()🎈DiscardPolicy()🎈Dis…

LNPMariadb數據庫分離|web服務器集群

LNP&Mariadb數據庫分離|web服務器集群 網站架構演變單機版LNMP獨立數據庫服務器web服務器集群與Session保持 LNP與數據庫分離1. 準備一臺獨立的服務器,安裝數據庫軟件包2. 將之前的LNMP網站中的數據庫遷移到新的數據庫服務器3. 修改wordpress網站配置…

2023.12.24 關于 Redis 中 String 類型內部編碼 及 應用場景

目錄 String 類型內部編碼 3 種內部編碼方式 String 類型應用場景 Cache 緩存 鍵名命名規則 計數(Counter) 共享會話(Session ) 手機驗證碼 總結 String 類型內部編碼 3 種內部編碼方式 int:用來表示 64 位 —…

vue3菜單權限管理實現

前提 你的菜單是根據路由動態生成的,具體可以參考這篇博客對el-menu組件進行遞歸封裝(根據路由配置動態生成) 描述 首先將路由分為常量路由constantRoute(所有用戶都有的路由)和異步路由asyncRoute(需要動…

Gradle 插件

自定義Gradle插件 - 簡書

小天使的小難題:新生兒疝氣的關注與溫馨呵護

引言: 新生兒疝氣是一種在出生后可能出現的常見情況,雖然通常不會造成長期影響,但對于家長而言,了解如何正確應對新生兒疝氣是至關重要的。本文將深入探討新生兒疝氣的原因、癥狀,以及家長在面對這一問題時應該采取的…

1224. 交換瓶子(藍橋杯/圖論)

題目: 1224. 交換瓶子 - AcWing題庫 輸入樣例1: 5 3 1 2 5 4輸出樣例1: 3輸入樣例2: 5 5 4 3 2 1輸出樣例2: 2 思路:圖論 1.將對應的位置與當前的瓶子序列相連形成環。 2.最少交換次數能形成的最多…

Vue中的事件委托(事件代理)使用方法介紹

事件委托(事件代理) 將原本需要綁定在子元素上的事件監聽器委托在父元素上,讓父元素充當事件監聽的職務。 事件委托是一種利用事件冒泡的特性,在父節點上響應事件,而不是在子節點上響應事件的技術。它能夠改善性能&a…

如何理解JDK、JRE、JVM區別與聯系

摘要:JDK是 Java 語言的軟件開發工具包(SDK)。在JDK的安裝目錄下有一個jre目錄,里面有兩個文件夾bin和lib,在這里可以認為bin里的就是jvm,lib中則是jvm工作所需要的類庫,而jvm和 lib合起來就稱為jre。 一、JDK JDK(Ja…

【【迭代16次的CORDIC算法-verilog實現】】

迭代16次的CORDIC算法-verilog實現 -32位迭代16次verilog代碼實現 CORDIC.v module cordic32#(parameter DATA_WIDTH 8d32 , // we set data widthparameter PIPELINE 5d16 // Optimize waveform)(input …

第十四章Java博客

lambda就是數學中的“λ”的讀音,lambda表達式是基于λ演算而得名的,因為lambda抽象(lambda abstraction)表示一個匿名的函數,于是開發語言也將lambda表達式用來表示匿名函數,也就是沒有函數名字的函數。C#…

maven管理工具使用package打包的時候無法將lib文件夾下的第三方jar包打入,上線打jar包后運行異常問題

問題描述&#xff1a; 調用第三方接口的時候通過手動引入了第三方的兩個jar包到我本項目的lib文件夾下&#xff0c;并在pom文件添加入下配置&#xff1a; <dependency><groupId>cn.xxxx.xxxx.core</groupId><artifactId>xxxx-core</artifactId>…