国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

MySQL 一則慢日志監控誤報的問題分析與解決

瀏覽:5日期:2023-10-06 13:18:31

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

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

后端使用的是基于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)

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

為了進一步驗證,我把閾值時間修改為600,竟然還是報出錯誤,執行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沒問題啊。

我自己在客戶端執行,確實是好好的,只過濾出了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;

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

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

為了方便說明,我創建了一個測試表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 一則慢日志監控誤報的問題分析與解決的詳細內容,更多關于MySQL慢日志監控誤報的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 亚洲欧美国产日韩天堂在线视 | 1024香蕉国产在线视频 | 国产精品理论片在线观看 | 国产精品国产三级国产专区5o | 厕拍精品 | 毛片日韩 | 国产精品人伦久久 | 114一级毛片免费 | 久久久久久久久久毛片精品美女 | 女人被男人桶 | 欧美成人精品一区二区 | 国产成人综合91精品 | 91综合精品网站久久 | 日本卡一卡2卡3卡4精品卡无人区 | 欧美片网站免费 | 欧美一区二区在线 | 多人伦精品一区二区三区视频 | 精品国产高清a毛片无毒不卡 | 久草在线视频资源 | 久久99亚洲精品久久久久 | 欧美精品亚洲人成在线观看 | 泰国情欲片寂寞的寡妇在线观看 | 成人丁香乱小说 | 欧美一级免费看 | 国产一区二区精品久久凹凸 | 欧美久久一区二区 | 欧美精品在欧美一区二区 | 一级特级aaa毛片 | 怡红院视频在线观看 | 亚洲图片国产日韩欧美 | 男人的天堂在线精品视频 | 老司机精品影院一区二区三区 | 亚洲香蕉久久一区二区三区四区 | 国产精品久久久精品三级 | 91伊人久久 | 欧美激情综合亚洲五月蜜桃 | 高清在线一区二区三区亚洲综合 | 欧美一区二区在线免费观看 | 久久视频免费观看 | 欧美国产精品亚洲精品第一区 | 国产亚洲女在线精品 |