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

MySQL 一則慢日志監(jiān)控誤報的問題分析與解決

 更新時間:2021年01月26日 15:09:29   作者:jeanron100  
這篇文章主要介紹了MySQL 一則慢日志監(jiān)控誤報的問題分析與解決,幫助大家更好的理解和使用MySQL,感興趣的朋友可以了解下

之前因為各種原因,有些報警沒有引起重視,最近放假馬上排除了一些潛在的人為原因,發(fā)現數據庫的慢日志報警有些奇怪,主要表現是慢日志報警不屬實,收到報警的即時通信提醒后,隔一會去數據庫里面去排查,發(fā)現慢日志的性能似乎沒有那么差(我設置的一個閾值是60)。

排查過幾次代碼層面的邏輯,沒有發(fā)現明顯的問題,幾次下來,問題依舊,這可激發(fā)了修正的念頭,決定認真看看到底是什么原因。

后端使用的是基于ORM的模式,數據都存儲在模型MySQL_slowlog_sql_history對應的表中。

代碼層面是類似如下的邏輯:

MySQL_slowlog_sql_history.objects.filter(create_time__gt='2020-01-29 11:00:00',Query_time_pct_95__gt=60)

傳入的時間是動態(tài)的,然后閾值取60秒,按照預期如果報警出來就肯定是有問題的。

為了進一步驗證,我把閾值時間修改為600,竟然還是報出錯誤,執(zhí)行7~8秒的慢查詢照樣會報出來。

我使用debug的方式得到了ORM解析得到的SQL:

SELECT...`mysql_slowlog_sql_history`.`create_time`, `mysql_slowlog_sql_history`.`memo` 
FROM `mysql_slowlog_sql_history` 
WHERE (`mysql_slowlog_sql_history`.`create_time` > '2020-01-29 11:00:00' AND `mysql_slowlog_sql_history`.`Query_time_pct_95` > '600') LIMIT 21; 
args=(u'2020-01-29 11:00:00', u'600')

看SQL沒問題啊。

我自己在客戶端執(zhí)行,確實是好好的,只過濾出了600秒以上的結果。

select ip_addr,db_port from mysql_slowlog_sql_history 
where create_time>'2020-01-29 00:00:00' and Query_time_pct_95 > 600;

對著這個結果我開始反思,到底是什么原因呢?

我看著模型的字段定義開始有所悟,然后快速驗證了一番。

為了方便說明,我創(chuàng)建了一個測試表test_dummy.

create table test_dummy(id int primary key auto_increment,Query_time_pct_95 varchar(100));

初始化幾條數據。

insert into test_dummy(Query_time_pct_95 ) values('8.83736'),('7.70056'),('5.09871'),('4.32582');
+----+-------------------+
| id | Query_time_pct_95 |
+----+-------------------+
| 1 | 8.83736      |
| 4 | 7.70056      |
| 7 | 5.09871      |
| 10 | 4.32582      |
+----+-------------------+
4 rows in set (0.00 sec)

然后使用如下的兩條語句來進行對比測試。

mysql> select *from test_dummy where Query_time_pct_95>600;
Empty set (0.00 sec)
mysql> select *from test_dummy where Query_time_pct_95>'600';
+----+-------------------+
| id | Query_time_pct_95 |
+----+-------------------+
| 1 | 8.837364     |
| 2 | 7.700558     |
+----+-------------------+
2 rows in set (0.00 sec)

可以看到,使用了整型數值的時候,沒有返回結果,而使用了字符類型的時候,匹配的結果是按照最左匹配的模式來進行過濾的,也就意味著在數據庫層面對于浮點數的處理還是差別很大的。

所以這個問題的快速修復方式就是在數據庫層面修改數據表的類型為float,而在精度損失方面這塊的影響是可以忽略不計的。

再次驗證,這個問題就沒有再次出現。

以上就是MySQL 一則慢日志監(jiān)控誤報的問題分析與解決的詳細內容,更多關于MySQL慢日志監(jiān)控誤報的資料請關注腳本之家其它相關文章!

相關文章

  • MySQL8.x登陸root用戶突然提示mysql_native_password的實現

    MySQL8.x登陸root用戶突然提示mysql_native_password的實現

    本文主要介紹了MySQL 8.x登陸root用戶突然提示mysql_native_password,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2024-08-08
  • MySql學習筆記之事務隔離級別詳解

    MySql學習筆記之事務隔離級別詳解

    這篇文章主要給大家介紹了關于MySql學習筆記之事務隔離級別的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-05-05
  • 點贊功能使用MySQL還是Redis

    點贊功能使用MySQL還是Redis

    本文主要介紹了點贊功能使用MySQL還是Redis,這是最近面試時被問到的1道面試題,本篇博客對此問題進行總結分享,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • MySQL快速插入一億測試數據

    MySQL快速插入一億測試數據

    本文主要介紹了MySQL快速插入一億測試數據,有時候測試需要大量的數據,需要的朋友們下面隨著小編來一起學習學習吧
    2021-06-06
  • MySQL8.0設置遠程訪問權限的方法

    MySQL8.0設置遠程訪問權限的方法

    這篇文章主要介紹了MySQL8.0設置遠程訪問權限的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-11-11
  • 關于MySQL的存儲過程與存儲函數

    關于MySQL的存儲過程與存儲函數

    存儲過程是在大型數據庫系統(tǒng)中,一組為了完成特定功能的SQL?語句集(這些SQL語句已經編譯過了),它存儲在數據庫中,一次編譯后永久有效,需要的朋友可以參考下
    2023-05-05
  • mysql使用物理備份安裝xtrabackup的詳細過程

    mysql使用物理備份安裝xtrabackup的詳細過程

    這篇文章主要介紹了mysql使用物理備份安裝xtrabackup的詳細過程,本文通過實例代碼給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧
    2024-05-05
  • mysql中的load命令使用方法

    mysql中的load命令使用方法

    使用mysql 中的load 命令,可以將txt 文件中的內容加載到數據庫表中
    2013-10-10
  • MySQL?原理與優(yōu)化之原數據鎖的應用

    MySQL?原理與優(yōu)化之原數據鎖的應用

    這篇文章主要介紹了MySQL?原理與優(yōu)化之原數據鎖的應用,MySQL?中原數據鎖是系統(tǒng)自動控制添加的,對于用戶來說無需顯示調用,當我們使用一張表的時候就會加上原數據鎖
    2022-08-08
  • MySQL尾部空格處理方法詳解

    MySQL尾部空格處理方法詳解

    這篇文章主要介紹了MySQL尾部空格處理方法詳解的相關資料,通過創(chuàng)建合適的索引來實現區(qū)分有尾部空格和沒有尾部空格的字符串,需要的朋友可以參考下
    2023-07-07

最新評論