關於Queries_per_sec 性能計數器

来源:https://www.cnblogs.com/CtripDBA/archive/2020/02/03/12254680.html
-Advertisement-
Play Games

【問題描述】 Queries_per_sec (QPS)是資料庫兩個比較重要的性能計數器指標。我們經常要求開發告知這個參數,以評估資料庫的一個負載情況。下麵的這段代碼連上伺服器,做一個簡單的查詢: using (MySqlConnection conn = new MySqlConnection() ...


【問題描述】

Queries_per_sec (QPS)是資料庫兩個比較重要的性能計數器指標。我們經常要求開發告知這個參數,以評估資料庫的一個負載情況。下麵的這段代碼連上伺服器,做一個簡單的查詢:

using (MySqlConnection conn = new MySqlConnection())
{
conn.ConnectionString = "Database=xx;Host=xx;Port=xx;User Id=xx; Password=xx; charset=utf8;pooling=true;";
MySqlCommand cmd = new MySqlCommand();
cmd.Connection = conn;
conn.Open();
cmd.CommandText = " select * from test where ID = 3";
cmd.ExecuteNonQuery();
conn.Close();
}

我們加一個迴圈,執行200萬次。可以看到Queries_per_sec 大約在930次/秒。

Questions_per_sec 大約在620次/秒

執行的時間從14:56:52開始到16:45:22結束,約6510秒,期間執行200萬次。根據我們的理解,QPS應該在 200萬/6510 = 310次/秒左右。但我們系統採集的Queries_per_sec或Questions_per_sec都和這個數據不符。Questions_per_sec是期望值的兩倍,Queries_per_sec是期望值的三倍。這是為什麼呢。

【問題分析】

性能計數器是我們從show global status採集而來。其中的Questions和Queries定義如下:

Questions
The number of statements executed by the server. This includes only statements sent to the server by clients and not statements executed within stored programs, unlike the Queries variable. This variable does not count COM_PING, COM_STATISTICS, COM_STMT_PREPARE, COM_STMT_CLOSE, or COM_STMT_RESET commands.
Queries
The number of statements executed by the server. This variable includes statements executed within stored programs, unlike the Questions variable. It does not count COM_PING or COM_STATISTICS commands.

這個定義有點複雜。我們在伺服器上開啟General Log, 就可以看到,上面的查詢其實還包含Init DB的操作:
3499308 Init DB testdb
3499308 Query select * from test where ID = 3
3499308 Init DB testdb
3499308 Query select * from test where ID = 3

所以,這就解釋了為何Questions_per_sec 比我們預期的多了一倍,這是因為有Init DB操作的緣故。
應該還有另外一個操作,使得Queries_per_sec 這個性能計數器是我們預期的QPS的三倍左右。我們跟蹤show global status like 'com_%'; 這個命令,可以發現下麵三個計數在增加:
1、Com_admin_commands
2、Com_change_db
3、Com_select

第二和第三比較好解釋,Com_Change_DB相當於我們的Init DB, COM_Select就是我們的SELECT查詢。而第一個Com_admin_commands就比較奇怪了。經查代碼,這是下麵的幾計數器的集合。其他的一般都用不到,能用到的就剩下COM_PING了。

COM_CHANGE_USER
COM_SHUTDOWN
COM_PING
COM_DEBUG
COM_BINLOG_DUMP_GTID
COM_BINLOG_DUMP

所以問題就比較清楚了。

【結論】

Queries_per_sec 比我們預期的QPS高三倍,是由於驅動程式對連接有Ping的一個檢驗動作。這個動作應該也算作Queries。在Questions里體現不出來。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 安裝 配置 打開系統Settings,Region & Language,Manage Installed Languages,安裝中文語言包,然後選擇Keyboard input method system為fcitx; 重啟系統; 在Region & Language,input Sources ...
  • centos系統搭建PXE網路安裝centos+ubuntu+Windows Centos搭建PXE,安裝部署操作系統 一 . 原理: 1.什麼是PXE: PXE(Pre-boot Execution Environment,預啟動執行環境)是由Intel公司開發的最新技術,工作於Client/Se ...
  • SVN倉庫備份和遷移 author: yunqimg(ccxtcxx0) 前言 本文主要是講 SVN 倉庫的全量備份和增量備份,只包括基本操作. 如有疑問請參考 References. 倉庫備份 svnadmin dump 1. 備份方式多樣 2. 如果版本數過多,dump的過程將非常慢 3. 備份 ...
  • 此篇文章為博主在Linux學習過程中的一些記錄,記錄在此方便查閱。 常用命令總結 + ls 顯示目錄內容 (list directory contents) + 不顯示隱藏的文件和子目錄 + 顯示目錄中所有的文件和子目錄(包括隱藏文件) + 顯示目錄中文件和子目錄的詳細信息(包括許可權、大小、創建/修 ...
  • RocksDB介紹RocksDB簡介RocksDB是基於C++語言編寫的嵌入式KV存儲引擎,它不是一個分散式的DB,而是一個高效、高性能、單點的資料庫引擎。它是由Facebook基於Google開源的kv存儲LevelDB開發開發。RocksDB使用LSM存儲引擎。它針對不同的生產環境進行調優,可以 ...
  • 關於點陣圖,可能大家不太熟悉, 那麼點陣圖能幹啥呢?點陣圖的內容其實就是普通的字元串,也就是byte數組,我們都知道 byte 8 位無符號整數 0 到 255 說個場景。比如你處理一些業務時候,往往會存在 是或者不是 這樣的數據,那麼這種數據還是頻繁去查看和請求,從數據方面和請求次數方面都是非常的大的。 ...
  • Mysql5.6安裝 下載好安裝包後,在bin目錄下用cmd打開,輸入mysqld install 【服務名】新建個服務 在windows+r輸入services.msc即可查看服務 怎樣使用mysql 在本地電腦上安裝好mysql伺服器後,使用命令開啟mysql服務,命令為net start my ...
  • 近來學習scrap分散式,需要用到redis,但以前沒接觸過,所以記錄一下自己的安裝過程。 準備:Mac,redis-5.0.4.tar.gz 1.壓縮包到官網下(建議下載穩定版)網址:redis.io 2.我把壓縮包放在了/usr/local/下麵。 3.打開終端,找到壓縮包,在當前目錄下輸入:t ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...