濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > MySQL 一則慢日志監(jiān)控誤報(bào)的問(wèn)題分析與解決

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

熱門標(biāo)簽:地圖標(biāo)注被騙三百怎么辦 云南語(yǔ)音外呼系統(tǒng)平臺(tái) 常州電銷外呼系統(tǒng)一般多少錢 天智外呼系統(tǒng) 北京人工外呼系統(tǒng)價(jià)錢 400電話鄭州申請(qǐng) 福州呼叫中心外呼系統(tǒng)哪家好 沃克斯電梯外呼線路圖 房產(chǎn)智能外呼系統(tǒng)品牌

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

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

后端使用的是基于ORM的模式,數(shù)據(jù)都存儲(chǔ)在模型MySQL_slowlog_sql_history對(duì)應(yīng)的表中。

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

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

傳入的時(shí)間是動(dòng)態(tài)的,然后閾值取60秒,按照預(yù)期如果報(bào)警出來(lái)就肯定是有問(wèn)題的。

為了進(jìn)一步驗(yàn)證,我把閾值時(shí)間修改為600,竟然還是報(bào)出錯(cuò)誤,執(zhí)行7~8秒的慢查詢照樣會(huì)報(bào)出來(lái)。

我使用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沒(méi)問(wèn)題啊。

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

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;

對(duì)著這個(gè)結(jié)果我開(kāi)始反思,到底是什么原因呢?

我看著模型的字段定義開(kāi)始有所悟,然后快速驗(yàn)證了一番。

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

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

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

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)

然后使用如下的兩條語(yǔ)句來(lái)進(jìn)行對(duì)比測(cè)試。

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)

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

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

再次驗(yàn)證,這個(gè)問(wèn)題就沒(méi)有再次出現(xiàn)。

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

您可能感興趣的文章:
  • 詳解mysql慢日志查詢
  • 關(guān)于Anemometer圖形化顯示MySQL慢日志的工具搭建及使用的詳細(xì)介紹
  • MySQL慢日志實(shí)踐小結(jié)
  • MySQL的慢日志線上問(wèn)題及優(yōu)化方案
  • mysql 5.5 開(kāi)啟慢日志slow log的方法(log_slow_queries)
  • MySQL中按時(shí)間獲取慢日志信息的方法
  • 根據(jù)mysql慢日志監(jiān)控SQL語(yǔ)句執(zhí)行效率
  • MySQL 慢日志相關(guān)知識(shí)總結(jié)

標(biāo)簽:沈陽(yáng) 移動(dòng) 黔東 拉薩 珠海 徐州 沈陽(yáng) 鹽城

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL 一則慢日志監(jiān)控誤報(bào)的問(wèn)題分析與解決》,本文關(guān)鍵詞  MySQL,一則,慢,日志,監(jiān)控,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL 一則慢日志監(jiān)控誤報(bào)的問(wèn)題分析與解決》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于MySQL 一則慢日志監(jiān)控誤報(bào)的問(wèn)題分析與解決的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    玛沁县| 保山市| 武平县| 环江| 鄯善县| 永寿县| 蒲江县| 宁远县| 六枝特区| 天等县| 北安市| 乌兰县| 吉安县| 浪卡子县| 襄城县| 遂川县| 根河市| 贵港市| 彝良县| 察哈| 宜兰县| 黎川县| 兴化市| 闸北区| 阿拉善左旗| 精河县| 永川市| 乐至县| 益阳市| 巴林右旗| 奉贤区| 伊金霍洛旗| 宜兴市| 彭州市| 吴忠市| 湟中县| 扎赉特旗| 桓仁| 马龙县| 大洼县| 绥宁县|