一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數(shù)據(jù)庫技術|

服務器之家 - 數(shù)據(jù)庫 - Mysql - MySQL 一則慢日志監(jiān)控誤報的問題分析與解決

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

2021-04-06 16:42jeanron100 Mysql

這篇文章主要介紹了MySQL 一則慢日志監(jiān)控誤報的問題分析與解決,幫助大家更好的理解和使用MySQL,感興趣的朋友可以了解下

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

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

后端使用的是基于ORM的模式,數(shù)據(jù)都存儲在模型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:

?
1
2
3
4
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秒以上的結果。

?
1
2
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.

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

初始化幾條數(shù)據(jù)。

?
1
2
3
4
5
6
7
8
9
10
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)

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

?
1
2
mysql> select *from test_dummy where Query_time_pct_95>600;
Empty set (0.00 sec)
?
1
2
3
4
5
6
7
8
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)

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

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

再次驗證,這個問題就沒有再次出現(xiàn)。

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

原文鏈接:https://cloud.tencent.com/developer/article/1586775

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久学生精品国产自在拍 | 门房秦大爷最新章节阅读 | 太紧太深了受不了黑人 | 特级毛片全部免费播放器 | 欧美色fx性乌克兰 | 国产亚洲精品美女久久久 | 国产精品自产拍在线观看2019 | 日韩成人一区ftp在线播放 | 日韩一区二区三区不卡视频 | 欧美人畜| 欧美性白人顶级hd | 91影视在线看免费观看 | 欧美一区二区三区精品国产 | 视频一区国产精戏刘婷30 | 国产成人免费视频 | 嫩草蜜桃| 成人国产精品一级毛片视频 | 国产一级毛片国语版 | caoporn超碰 | 国产精品久久毛片蜜月 | 免费的网址 | 国产精品亚洲片夜色在线 | 7777色鬼xxxx欧美色夫 | 日本午夜大片免费观看视频 | 精品欧美一区二区三区在线观看 | 欧美亚洲国产精品久久久 | 暖暖 免费 高清 日本 在线1 | 亚洲精品视频导航 | 久久综合狠狠综合久久综合88 | 国产成人刺激视频在线观看 | 我被男人下药添得好爽 | 果冻传媒九一制片厂 | 成人黄页网站 | 成人福利免费在线观看 | 国产高清在线精品一区二区三区 | 四虎精品成人免费视频 | 久久大胆视频 | 俄罗斯美女尿尿 | 欧美日韩高清完整版在线观看免费 | 娇妻被健身教练挺进小说阅读 | 办公室恋情在线观看 |