欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何使用mysqladmin獲取一個mysql實例當(dāng)前的TPS和QPS

 更新時間:2020年11月09日 09:43:55   作者:AsiaYe  
這篇文章主要介紹了如何使用mysqladmin這個工具來獲取一個mysql實例當(dāng)前的TPS和QPS,幫助大家更好的管理數(shù)據(jù)庫,感興趣的朋友可以了解下

  mysqladmin是mysql官方的一款執(zhí)行管理端的客戶端程序,可以利用它對MySQL數(shù)據(jù)庫服務(wù)進行操作,在MySQL5.5及以前的版本中,最常用的方法是用它來關(guān)閉mysql實例:

mysqladmin -uxxx -pxxx -Pxxx -hxxx  shutdown

   隨著mysql版本的升級,mysql5.7中已經(jīng)可以直接使用shutdown命令來進行mysql服務(wù)的關(guān)閉了。mysql8.0版本中,可以使用restart命令來對mysql服務(wù)進行重啟,mysqladmin這個工具在日常的運維場景中用的越來越少。

    今天來看如何使用mysqladmin這個工具來獲取一個mysql實例當(dāng)前的TPS和QPS呢?要解決這個問題,首先得知道TPS和QPS的參考指標(biāo)。在MySQL中,我們可以使用show global status命令來查看mysql當(dāng)前的指標(biāo)情況,如下:

mysql--dba_admin@127.0.0.1:(none) 13:37:50>>show global status;
+------------------------------------------+----------------+
| Variable_name       | Value   |
+------------------------------------------+----------------+
| Aborted_clients       | 85032   |
| Aborted_connects       | 176   |
| Binlog_cache_disk_use     | 3293   |
| Binlog_cache_use       | 14631673326 |
| Binlog_stmt_cache_disk_use    | 13    |
| Binlog_stmt_cache_use     | 9948429  |
| Bytes_received       | 19921975442457 |
| Bytes_sent        | 13553543054684 |
| Com_admin_commands      | 913630   |
| Com_assign_to_keycache     | 0    |
| Com_alter_db        | 0    |
| Com_alter_db_upgrade      | 0    |

有這么幾個指標(biāo)比較重要:

1、Questions:

MySQL服務(wù)器執(zhí)行的語句數(shù),它僅包含客戶端發(fā)送給服務(wù)器的語句,不包含存儲過程中執(zhí)行的語句,該參數(shù)不計算Com_ping,Com_statistics,Com_stmt_prepare,Com_stmt_close以及Com_stat_reset命令,但是包含show命令、dml命令。不包含主從復(fù)制的語句。

2、Queries:

服務(wù)器執(zhí)行的語句數(shù),與Questions參數(shù)不同,他包含了在存儲過程中執(zhí)行的語句以及內(nèi)置的主從復(fù)制語句,它不計算Com_ping和Com_statistics命令

3、Com_xxx:

代表xxx語句已經(jīng)執(zhí)行的次數(shù),每種類型都有一個狀態(tài)變量,舉例有Com_select,Com_insert,Com_delete,Com_update,Com_commit,Com_rollback等等。

通常情況下,計算TPS和QPS的方案有如下幾個:

方案一、如果考慮的是MySQL服務(wù)器上執(zhí)行的所有SQL,基于Queries來計算QPS,基于Com_commit和Com_rollback的代數(shù)和來計算TPS

方案二、如果僅僅考慮業(yè)務(wù)方通過命令行執(zhí)行的所有SQL,基于Question來計算QPS,基于Com_commit和Com_rollback的代數(shù)和來計算TPS

方案三、基于Com_xxx的status來計算QPS和TPS

以下是使用mysqladmin的方案來看TPS和QPS的命令:

[root ~]#./mysqladmin -r -i 2 -uroot -pxxxxxx -P4306 --socket=/data/mysql_4306/tmp/mysql.sock ext| awk '/Queries/{printf("QPS:%d\n",$4)}'
mysqladmin: [Warning] Using a password on the command line interface can be insecure.
QPS:55668415
QPS:1
QPS:34
QPS:32
QPS:108
QPS:6
QPS:7

[root ~]# ./mysqladmin -r -i 2 -uroot -pxxxxxx -P4306 --socket=/data/mysql_4306/tmp/mysql.sock ext| awk '/Com_commit/{printf("TPS:%d\n",$4)}'
mysqladmin: [Warning] Using a password on the command line interface can be insecure.
TPS:27449691
TPS:56
TPS:1
TPS:2
TPS:28

這里針對參數(shù)-r和-i進行解釋,我們使用mysqladmin --help指令,過濾這兩個參數(shù):

  • -r, --relative     

Show difference between current and previous values when used with -i. Currently only works with extended-status.

翻譯一下,就是現(xiàn)實當(dāng)前和之前的值之間的差距,需要配合-i使用,再來看-i參數(shù):

  • -i, --sleep=#       Execute commands repeatedly with a sleep between.

也就是時間間隔

除此之外,后面還有一個ext的選項,看這個選項的解釋:

extended-status:

    Gives an extended status message from the server #翻譯一下,就是給出更多的MySQL服務(wù)器的狀態(tài)信息

這樣上面的命令就很容易進行解釋了。使用-r參數(shù)來計算不同的狀態(tài)變量之間的差值,然后-i參數(shù)控制時間長度,設(shè)置為1代表每秒鐘的差值,ext代表輸出更多MySQL的狀態(tài)信息??梢苑奖愕挠嬎鉚PS和QPS,不同的計算方法略有差異,可以根據(jù)不同場景,來計算更為準(zhǔn)確的TPS和QPS值。

計算TPS和QPS的時候,有幾個標(biāo)準(zhǔn),可以酌情替換:

1、com_commit不會記錄隱式提交的事務(wù),所以如果開了隱式提交使用com_commit計算tps會不準(zhǔn)。

2、如果數(shù)據(jù)庫中存在比較多的myisam表,則計算還是questions 比較合適。

3、如果數(shù)據(jù)庫中存在比較多的innodb表,則計算以com_*數(shù)據(jù)來源比較合適。

4、Questions 是記錄了從mysqld啟動以來所有的select,dml 次數(shù)包括show 命令的查詢的次數(shù)。這樣多少有失準(zhǔn)確性,比如很多數(shù)據(jù)庫有監(jiān)控系統(tǒng)在運行,每5秒對數(shù)據(jù)庫進行一次show 查詢來獲取當(dāng)前數(shù)據(jù)庫的狀態(tài),而這些查詢就被記錄到QPS,TPS統(tǒng)計中,造成一定的"數(shù)據(jù)污染".

5、TPS在某些隱式提交開啟的情況下,可以使用Com_insert + Com_update + Com_delete來查看。

最后,給出判斷mysql是否存活的一種方法:

[root ~]# ./mysqladmin -r -i 2 -uroot -pdba@JJMatch -P4306 --socket=/data/mysql_4306/tmp/mysql.sock ping
mysqladmin: [Warning] Using a password on the command line interface can be insecure.
mysqld is alive
mysqld is alive
mysqld is alive

使用mysqladmin的ping命令來查看mysql的存活情況。

隨著MySQL的升級,mysqladmin工具的使用頻率會越來越少,幾乎都是通過通過mysql工具來實現(xiàn)日常的需求,mysql8.0版本的mysqladmin工具在mysql5.7的基礎(chǔ)上略有調(diào)整,有興趣可以自己研究。

以上就是如何使用mysqladmin獲取一個mysql實例當(dāng)前的TPS和QPS的詳細(xì)內(nèi)容,更多關(guān)于mysqladmin 統(tǒng)計mysql T/QPS的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 詳解記錄MySQL中l(wèi)ower_case_table_names的坑

    詳解記錄MySQL中l(wèi)ower_case_table_names的坑

    這篇文章主要介紹了詳解記錄MySQL中l(wèi)ower_case_table_names的坑,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • MySQL 表字段太多超長問題解決方案

    MySQL 表字段太多超長問題解決方案

    在設(shè)計MySQL數(shù)據(jù)庫時,常遇到表字段超長問題,這是由字段數(shù)量過多或字段定義過長引起的,MySQL對字段數(shù)量和行大小有嚴(yán)格限制,超過限制將無法正常操作,本文就來介紹一下解決方法,感興趣的可以了解一下
    2024-10-10
  • MySQL基礎(chǔ)教程之DML語句詳解

    MySQL基礎(chǔ)教程之DML語句詳解

    DML 語句是指對數(shù)據(jù)庫中表的記錄進行的操作,下面這篇文章主要給大家介紹了關(guān)于MySQL基礎(chǔ)教程之DML語句的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2021-12-12
  • MySQL在線開啟或禁用GTID模式

    MySQL在線開啟或禁用GTID模式

    本文詳細(xì)講解了MySQL在線開啟或禁用GTID模式的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-11-11
  • MySQL常用聚合函數(shù)詳解

    MySQL常用聚合函數(shù)詳解

    下面小編就為大家?guī)硪黄狹ySQL常用聚合函數(shù)詳解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-06-06
  • Can't connect to MySQL server on localhost (10061)解決方法

    Can't connect to MySQL server 

    今天在安裝mysql后使用mysql命令連接mysql時報錯?Can't connect to MySQL server on localhost (10061),一般是因為mysql服務(wù)沒有啟動或者用戶名密碼不正確
    2011-03-03
  • MySQL使用LOAD_FILE()函數(shù)方法總結(jié)

    MySQL使用LOAD_FILE()函數(shù)方法總結(jié)

    在本篇文章里小編給大家分享了關(guān)于MySQL使用LOAD_FILE()函數(shù)方法和相關(guān)知識點,需要的朋友們學(xué)習(xí)下。
    2019-03-03
  • mysql5.7.14 解壓版安裝配置方法圖文教程(win10)

    mysql5.7.14 解壓版安裝配置方法圖文教程(win10)

    這篇文章主要為大家詳細(xì)介紹了win10下mysql5.7.14 winx64安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-12-12
  • MYSQL必知必會讀書筆記第十和十一章之使用函數(shù)處理數(shù)據(jù)

    MYSQL必知必會讀書筆記第十和十一章之使用函數(shù)處理數(shù)據(jù)

    這篇文章主要介紹了MYSQL必知必會讀書筆記第十和十一章之使用函數(shù)處理數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下
    2016-05-05
  • 兩大步驟教您開啟MySQL 數(shù)據(jù)庫遠(yuǎn)程登陸帳號的方法

    兩大步驟教您開啟MySQL 數(shù)據(jù)庫遠(yuǎn)程登陸帳號的方法

    在工作實踐和學(xué)習(xí)中,如何開啟 MySQL 數(shù)據(jù)庫的遠(yuǎn)程登陸帳號算是一個難點的問題,以下內(nèi)容便是在工作和實踐中總結(jié)出來的兩大步驟,能幫助DBA們順利的完成開啟 MySQL 數(shù)據(jù)庫的遠(yuǎn)程登陸帳號。
    2011-03-03

最新評論