中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么解決MySQL數據庫出現慢查詢問題

發布時間:2021-11-08 10:56:38 來源:億速云 閱讀:433 作者:iii 欄目:MySQL數據庫

這篇文章主要講解了“怎么解決MySQL數據庫出現慢查詢問題”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“怎么解決MySQL數據庫出現慢查詢問題”吧!

1、MySQL數據庫當出現慢查詢,是比較危險的,一旦有其他的DDL操作,可能會造成整個數據庫的等待

可以分以下幾種情況:

當表是MyiSAM表,對表有慢查詢,不阻塞Select,對該表的其他DML,DDL操作都會被阻塞,比如出現Wating for table level lock,數據庫中一定不能還存在MyiSAM表

當表是Innodb表,當表上有慢查詢,不阻塞Select 和DML,其他的DDL操作都會被阻塞,比如出現waiting for table metadata lock

綜上,當數據庫中存在慢查詢時,是比較危險的,當執行備份,create index ,alter table , flush table 等操作時就會造成數據庫的等待

解決辦法:

1、對數據庫中執行時間較長的Select進行監控,并及時報警

2、如果允許的話,寫腳本,發現較長的select語句,直接kill,并記錄日志中

-B, --batch Don't use history file. Disable interactive behavior.

-s, --silent Be more silent. Print results with a tab as separator,each row on new line.

-e, --execute=name Execute command and quit. (Disables --force and historyfile.)

#如果數據庫中當前有大量的select,可以過濾掉,只kill waiting的

cat killWaitSession.sh

#!/bin/bash
for i in mysql -Bse 'show full processlist' | grep -i select |grep -i "Waiting | awk '{print $1}'
do
mysql -Bse "kill $i"
done

show processlist的command的狀態有很多,其中Query代表正在執行的命令

Query : The thread is executing a statement.

cat killLongQuerySession.sh

#!/bin/bash
executetime=(mysql -Bse 'show processlist'| grep 'Query'|awk '{print $6 " " $1}'|sort -rn|head -1) #第6列是運行時間,第一列為session id
time=${executetime[0]}
id=${executetime[1]}
while :
do
maxtime=300
if [ $time -gt $maxtime ] ; then
echo $time $id >> /tmp/killqueryid.log
mysql -Bse "kill $id"
#else

echo $time $id

fisleep 10 #睡眠10s

done

按MySQL中執行時間反向排序

mysqladmin processlist --verbose |grep 'Query'|awk -F "|" '{print $7 $2 $9}'|sort -rn -k1

感謝各位的閱讀,以上就是“怎么解決MySQL數據庫出現慢查詢問題”的內容了,經過本文的學習后,相信大家對怎么解決MySQL數據庫出現慢查詢問題這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

大姚县| 芦溪县| 登封市| 昂仁县| 西充县| 曲周县| 达日县| 蒙山县| 新兴县| 德江县| 吉木乃县| 北安市| 青海省| 台南市| 新宁县| 宜宾县| 秦安县| 吉木乃县| 阳城县| 星子县| 九江市| 灌云县| 吉安县| 泰顺县| 广灵县| 隆德县| 三台县| 章丘市| 博客| 巩义市| 沽源县| 巴塘县| 洛阳市| 安新县| 遂川县| 商南县| 吉安县| 金川县| 多伦县| 湘潭县| 隆安县|