SHOW PROCESSLIST 最多能顯示多長的 SQL?

来源:https://www.cnblogs.com/ivictor/p/18251976
-Advertisement-
Play Games

在 MySQL 中,如果我們想查看實例當前正在執行的 SQL,常用的命令是SHOW PROCESSLIST。 但如果 SQL 過長的話,就會被截斷。這時,我們一般會用SHOW FULL PROCESSLIST來查看完整的 SQL。 最近碰到一個 case,發現無論是使用 SHOW PROCESSLI ...


在 MySQL 中,如果我們想查看實例當前正在執行的 SQL,常用的命令是SHOW PROCESSLIST

但如果 SQL 過長的話,就會被截斷。這時,我們一般會用SHOW FULL PROCESSLIST來查看完整的 SQL。

最近碰到一個 case,發現無論是使用 SHOW PROCESSLISTSHOW FULL PROCESSLIST,還是 performance_schema.processlist 都無法獲取完整的 SQL,反倒 information_schema.processlist 可以。

最後發現,SHOW FULL PROCESSLIST無法查看完整的 SQL 竟然與 performance_schema_show_processlist 參數有關。

SHOW PROCESSLIST 的實現方式

SHOW PROCESSLIST預設是從線程管理器(Global_THD_manager)中獲取線程信息。

這種實現方式會持有全局互斥鎖。在負載高的場景,會對資料庫的性能有一定的負面影響。

所以一般都推薦使用 performance_schema.processlist,這種方式不會持有全局鎖。

在 MySQL 8.0.22 中,引入了 performance_schema_show_processlist 參數,可設置SHOW PROCESSLIST的實現方式。

當該參數設置為 ON 時,會使用 performance_schema.processlist 的實現方式。

當參數設置為 OFF(預設值) 時,會使用傳統的實現方式。

三種不同查詢方式對 SQL 的長度限制

下麵我們看看 SHOW PROCESSLIST, information_schema.processlist, performance_schema.processlist 這三種不同的查詢方式對 SQL 的長度限制。

因為 SQL 是在 INFO 列中存儲的,所以,SQL 的最大長度實際上是由 INFO 列決定的。

SHOW PROCESSLIST

SHOW PROCESSLIST的輸出中 INFO 列的最大長度與 performance_schema_show_processlist 有關。

當 performance_schema_show_processlist 等於 OFF 時,無論是SHOW PROCESSLIST,還是SHOW FULL PROCESSLIST,調用的都是 mysqld_list_processes 函數。

// sql/sql_show.cc
void mysqld_list_processes(THD *thd, const char *user, bool verbose,
                           bool has_cursor) {
  Item *field;
  mem_root_deque<Item *> field_list(thd->mem_root);
  Thread_info_array thread_infos(thd->mem_root);
  size_t max_query_length =
      (verbose ? thd->variables.max_allowed_packet : PROCESS_LIST_WIDTH);
  Protocol *protocol = thd->get_protocol();
  DBUG_TRACE;
  
  ...
  field_list.push_back(field = new Item_empty_string("Info", max_query_length));
  ...
}

可以看到,INFO 列的最大長度由 max_query_length 決定,而 max_query_length 的取值又與 verbose 有關。

當執行SHOW FULL PROCESSLIST時, verbose 為 true,此時 max_query_length 等於 max_allowed_packet。

當執行SHOW PROCESSLIST時,verbose 為 false,此時 max_query_length 等於 PROCESS_LIST_WIDTH,而 PROCESS_LIST_WIDTH 是個常量,大小為 100。

constexpr const size_t PROCESS_LIST_WIDTH{100};

當 performance_schema_show_processlist 等於 ON 時,無論是SHOW PROCESSLIST,還是SHOW FULL PROCESSLIST,調用的都是build_processlist_query 函數。

// sql/sql_show_processlist.cc
bool build_processlist_query(const POS &pos, THD *thd, bool verbose) {
  LEX_STRING info_len;
  /*
    Default Info field length is 100. Verbose field length is limited to the
    size of the INFO columns in the Performance Schema.
  */
  assert(PROCESS_LIST_WIDTH == 100);
  if (verbose) {
    if (lex_string_strmake(thd->mem_root, &info_len, "1024", 4)) return true;
  } else {
    if (lex_string_strmake(thd->mem_root, &info_len, "100", 3)) return true;
  }
  ...
  /* Info length is either "100" or "1024" depending on verbose */
  Item_int *item_info_len = new (thd->mem_root) Item_int(pos, info_len);
  if (item_info_len == nullptr) return true;
  ...
}

當執行SHOW FULL PROCESSLIST時, verbose 為 true,此時 info_len 等於 1024。

當執行SHOW PROCESSLIST時,verbose 為 false,此時 info_len 等於 100。

information_schema.processlist

information_schema.processlist 表中 INFO 的長度是在Fill_process_list中限制的。

// sql/sql_show.cc
class Fill_process_list : public Do_THD_Impl {
  ...
  void operator()(THD *inspect_thd) override {
    
    /* INFO */
    mysql_mutex_lock(&inspect_thd->LOCK_thd_query);
    {
      const char *query_str = nullptr;
      size_t query_length = 0;
      ...
      if (query_str) {
        const size_t width = min<size_t>(PROCESS_LIST_INFO_WIDTH, query_length);
        table->field[7]->store(query_str, width, inspect_thd->charset());
        table->field[7]->set_notnull();
      }
    }
    ...
  }
};

INFO 的長度取 PROCESS_LIST_INFO_WIDTH 和 query_length(SQL 的實際長度)的最小值。

所以,INFO 列的最大長度由 PROCESS_LIST_INFO_WIDTH 決定,而 PROCESS_LIST_INFO_WIDTH 也是個常量,值為 65535。

constexpr const size_t PROCESS_LIST_INFO_WIDTH{65535};

performance_schema.processlist

performance_schema.processlist 表中 INFO 的長度是在pfs_set_thread_info_vc中限制的。

// storage/perfschema/pfs.cc
void pfs_set_thread_info_vc(const char *info, uint info_len) {
  pfs_dirty_state dirty_state;
  PFS_thread *pfs = my_thread_get_THR_PFS();

  if (likely(pfs != nullptr)) {
    if (info_len > sizeof(pfs->m_processlist_info)) {
      info_len = sizeof(pfs->m_processlist_info);
    }
    pfs->m_stmt_lock.allocated_to_dirty(&dirty_state);
    if (info != nullptr && info_len > 0) {
      memcpy(pfs->m_processlist_info, info, info_len);
    }
    pfs->m_processlist_info_length = info_len;
    pfs->m_stmt_lock.dirty_to_allocated(&dirty_state);
  }
}

可以看到,INFO 列的最大長度是由 pfs->m_processlist_info 決定的,而 m_processlist_info 是個字元數組,它的最大長度由 COL_INFO_SIZE 決定。

而 COL_INFO_SIZE 又等於 COL_INFO_CHAR_SIZE * 1。其中,COL_INFO_CHAR_SIZE 是一個常量,值為 1024。

// storage/perfschema/pfs_instr.h
char m_processlist_info[COL_INFO_SIZE];

// storage/perfschema/pfs_column_types.h
#define COL_INFO_CHAR_SIZE 1024
/** Size of INFO columns, in bytes. */
#define COL_INFO_SIZE (COL_INFO_CHAR_SIZE * 1)

結論

  1. 如果查詢的是 information_schema.processlist, INFO 列的最大長度是 65535。

  2. 如果查詢的是 performance_schema.processlist,INFO 列的最大長度是 1024。

  3. 如果執行的是SHOW PROCESSLIST,無論 performance_schema_show_processlist 是 ON 還是 OFF, INFO 列的最大長度都是 100。

  4. 如果執行的是SHOW FULL PROCESSLIST

    • 當 performance_schema_show_processlist 等於 OFF 或 MySQL 8.0.22 之前的版本 , INFO 列的最大長度等於 max_allowed_packet。
    • 當 performance_schema_show_processlist 等於 ON 時,INFO 列的最大長度是 1024。

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

-Advertisement-
Play Games
更多相關文章
  • 線程順序迴圈執行的場景在多線程編程中並不罕見,尤其是在需要協調多個線程按特定順序重覆執行任務的情況下。以下是幾個常見的例子: 生產者-消費者模型:在這種模型中,生產者線程生成數據並將其放入緩衝區,而消費者線程從緩衝區取出數據進行處理。這種情況下,生產者和消費者線程通常按順序交替運行。 流水線處理:在 ...
  • 如果把shell命令比成蓋房子的磚瓦,那shell腳本就是用一塊塊磚瓦建起來的房子。 腳本的第一行必須寫成類似下麵這樣的形式: #!/bin/bash #指定解釋器,其他還有dash,Python 等 變數 1.變數定義,賦值,引用 變數由字母和數字組成,值由雙引號包含,賦值號的兩邊不能有空格,例: ...
  • 目錄makefile 定義變數的方式1.遞歸定義2 直接定義3 條件定義方式4 追加變數值5 引用並修改變數值6 overrideVPATH用法:1 VPATH vpath各種規則1.隱式規則(Implicit Rules)2.靜態規則(Static Pattern Rules)3. 多目標規則(M ...
  • 瞭解更多關於bootloader 的C語言實現,請加我Q扣: 1273623966 (驗證信息請填 bootloader),歡迎咨詢或定製bootloader(線上升級程式)。 不知道為什麼,現在工業控制領域也向汽車領域學習,產品需要帶bootloader, 產品出貨後也要可以通過bootloade ...
  • 虛擬機添加磁碟與linux邏輯捲擴容 1.1 虛擬機添加磁碟 1.1.1. 檢查linux系統的磁碟分區及邏輯捲的相關信息是否正常 (1)cat /etc/redhat-release查看系統版本【適用於RHEL及CentOS】: 我已自己電腦上的虛擬機,50G記憶體2G運行記憶體為例 >>> (2)d ...
  • nslookup 是一個網路診斷工具,用於查詢功能變數名稱系統(DNS)記錄,將功能變數名稱解析為IP地址,或者查詢其他DNS記錄類型,如MX(郵件交換記錄)、CNAME(別名記錄)等。以下是一些常見Linux發行版安裝 及使用nslookup 的方法: Debian/Ubuntu 及其衍生版安裝 使用 apt 包 ...
  • 在學習Hadoop工具中的Flume時,有的小伙伴會遇到這句話: “Flume要想將數據輸出到HDFS,必須持有Hadoop相關jar包” 然後小伙伴就懵逼了,這些包要去什麼地方來找呢? (遠在天邊,近在眼前) 首先,我們需要的包有 commons-configuration-1.6.jar、 ha ...
  • 概述 explain 關鍵字可以模擬執行 sql 查詢語句,輸出執行計劃,分析查詢語句的執行性能 使用方式如下:explain + sql explain select * from t1 執行計劃各欄位含義 1. id 如果 id 序號相同,從上往下執行 如果 id 序號不同,序號大先執行 如果兩 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...