校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識(shí)庫 > MySQL性能突然下降的原因

MySQL性能突然下降的原因

熱門標(biāo)簽:石家莊電商外呼系統(tǒng) 廣東人工電話機(jī)器人 南通自動(dòng)外呼系統(tǒng)軟件 信陽穩(wěn)定外呼系統(tǒng)運(yùn)營商 日照旅游地圖標(biāo)注 芒果電話機(jī)器人自動(dòng)化 申請(qǐng)外呼電話線路 湖南人工外呼系統(tǒng)多少錢 百度地圖圖標(biāo)標(biāo)注中心

有時(shí)會(huì)碰到這樣的情況,一條 SQL 在平時(shí)執(zhí)行沒問題,很快。但是突然某個(gè)時(shí)間執(zhí)行的就會(huì)很慢,而且這種場景并不能復(fù)現(xiàn),只能隨機(jī)發(fā)送的。

SQL 執(zhí)行突然變慢的原因

在之前講解 MySQL Redo log 時(shí),說到了 WAL 機(jī)制,為了保證 MySQL 更新的速度,在進(jìn)行更新操作時(shí),先將更新內(nèi)容寫入 redo log,后續(xù)系統(tǒng)空閑時(shí),再將 redo log 的內(nèi)容應(yīng)用到磁盤。

當(dāng)內(nèi)存數(shù)據(jù)頁(redo log)和磁盤數(shù)據(jù)頁內(nèi)容不一致時(shí),將該內(nèi)存也稱為 “臟頁”。將內(nèi)存數(shù)據(jù)寫入到磁盤后,數(shù)據(jù)一致,內(nèi)存頁稱為 "干凈頁"。

在內(nèi)存數(shù)據(jù)寫入磁盤時(shí),這個(gè)過程稱為 flush 過程。SQL 突然執(zhí)行變得很慢,性能下降。原因就可能和 flush 操作有關(guān)。

因?yàn)樵谶M(jìn)行 flush 操作時(shí),更新操作會(huì)等待 redo log 的寫入。

引起 flush 操作的原因

場景一:redo log 日志已經(jīng)記滿。這時(shí)系統(tǒng)會(huì)停止更新操作,將 check point 向前推進(jìn),讓 redo log 留出空間可以繼續(xù)寫。

這里假設(shè) CP 到 CP‘ 間隙已經(jīng)寫入到磁盤,這部分就變成了干凈頁,此時(shí) write pos 就可以寫入這部分區(qū)域了。

場景二:系統(tǒng)內(nèi)存不足,需要新的內(nèi)存頁時(shí),發(fā)現(xiàn)內(nèi)存不夠用了,就需要淘汰一些數(shù)據(jù)頁。如果淘汰時(shí),這時(shí)數(shù)據(jù)頁時(shí)臟頁,就要將臟頁寫到磁盤。

這時(shí)有個(gè)問題是,命名 redo log 中的內(nèi)容已經(jīng)被記錄到日志中了,假如內(nèi)存滿了,直接刪除不就可以嗎?下次讀入時(shí),再把 redo log 日志中的內(nèi)容應(yīng)用到磁盤。

沒有選擇直接清空內(nèi)存,是從性能考慮的,因?yàn)樵诓樵償?shù)據(jù)時(shí),有兩種情況:

  • 首先數(shù)據(jù)頁在內(nèi)存中,內(nèi)存是就是正確的結(jié)果,直接返回
  • 內(nèi)存里沒有數(shù)據(jù),從數(shù)據(jù)文件上讀入內(nèi)存。

所以這樣效率比較高。

場景三:MySQL 會(huì)在系統(tǒng)空閑時(shí),進(jìn)入 flush 操作。

場景四:在 MySQL 正常關(guān)閉時(shí),會(huì)把內(nèi)存臟頁 flush 到磁盤上。

引起 flush 對(duì)性能的影響

對(duì)于第三,四場景來說,是比較正常的情況,不需要考慮性能問題。

對(duì)于第一種場景,InnoDB 會(huì)盡量避免,因?yàn)樵谶@種情況下,整個(gè)系統(tǒng)不再接受更新。

但有時(shí)出現(xiàn)人為的配置錯(cuò)誤,比如內(nèi)存為 128 GB,innodb_io_capacity 設(shè)置為 20000 的實(shí)例。通常建議將 redo log 設(shè)置成 4 個(gè) 1GB 的文件。但由于配置錯(cuò)誤,設(shè)置成 100M 的文件。

這里由于 redo log 設(shè)置的太小,很快就會(huì)被寫滿。write pos 一直追著 check point. 這時(shí),系統(tǒng)只能停止所有更新,推進(jìn) checkpoint.

表現(xiàn)就是,磁盤 IO 很小,但是出現(xiàn)間歇性的性能下降。

對(duì)于第二種場景,內(nèi)存不夠用的情況,InnoDB 會(huì)用緩沖池(buffer pool)管理內(nèi)存

內(nèi)存頁在緩沖池中會(huì)有三種狀態(tài):

  • 沒用使用的數(shù)據(jù)頁
  • 使用了,但是是干凈頁
  • 使用了,是臟頁

每個(gè)數(shù)據(jù)頁頭部有LSN,8字節(jié),每次修改都會(huì)變大。

對(duì)比這個(gè) LSN 跟 checkpoint 的 LSN,比checkpoint小的一定是干凈頁

由于 InnoDB 的策略是盡可能使用內(nèi)存,所以對(duì)于長時(shí)間運(yùn)行的庫來說,未被使用的頁面很少。

當(dāng)發(fā)現(xiàn)想讀入的數(shù)據(jù)頁沒有在內(nèi)存中時(shí),必須到緩沖池申請(qǐng)數(shù)據(jù)頁。并會(huì)把最久不用得數(shù)據(jù)頁從內(nèi)存中淘汰

如果是干凈頁,直接釋放使用
如果是臟頁,必須先刷盤,變成干凈頁才能復(fù)用
當(dāng)時(shí),如果在下面的情況進(jìn)行刷臟頁,會(huì)明顯影響性能:

要淘汰的臟頁太多,導(dǎo)致查詢響應(yīng)時(shí)間較長。
日志寫滿,更新被阻塞。
為了解決這個(gè)問題,InnoDB 使用控制臟頁比例的機(jī)制,來避免上面的情況。

InooDB 控制刷臟頁的策略

在 InnoDB 中,通過 innodb_io_capacity 參數(shù),來告訴 InnoDB 目前主機(jī)的磁盤能力是多少,這個(gè)值建議設(shè)置成磁盤的 IOPS.

可以通過 fio 這個(gè)工具來測(cè)試:

fio -filename=$filename -direct=1 -iodepth 1 -thread -rw=randrw -ioengine=psync -bs=16k -size=500M -numjobs=10 -runtime=10 -group_reporting -name=mytest

由于 innodb_io_capacity 導(dǎo)致的性能問題很常見,比如有時(shí)系統(tǒng)吞吐量(TPS)很低,寫入很慢,但是磁盤 IO 并不高。就有可能是該參數(shù)設(shè)置的不正確。例如,innodb_io_capacity 的值設(shè)置的很低,但是磁盤用的 SSD,導(dǎo)致 InooDB 認(rèn)為系統(tǒng)能力很差,所以刷臟頁特別慢。造成臟頁累計(jì),影響查詢和更新性能。

InnoDB 在刷盤時(shí)主要考慮兩個(gè)因素:

  1. 臟頁的比例
  2. redo log 寫盤速度

會(huì)通過這兩個(gè)因素單獨(dú)先算出兩個(gè)數(shù)字。

innodb_max_dirty_pages_pct 臟頁比例上限,默認(rèn) 75%.

InnoDB 會(huì)根據(jù)臟頁的比例(M),算出范圍在 0 - 100 的數(shù)字。,過程稱為 F1(M)

# M 臟頁比例
F1(M)
{
 if M>=innodb_max_dirty_pages_pct then
  return 100;
 return 100*M/innodb_max_dirty_pages_pct;
}

除此之外,InnoDB 每次寫入日志都會(huì)有一個(gè)序號(hào) N. 然后根據(jù) N 再算出一個(gè) 0 到 100 的數(shù)字,這個(gè)計(jì)算過程稱為 F2(N)

N: 當(dāng)前寫入的序號(hào)和 checkpoint 對(duì)應(yīng)序號(hào)之間的差值。

最后,根據(jù) F1(M)和 F2(N)兩個(gè)值,取其中較大的值為 R,之后引擎就可以按照 innodb_io_capacity * R 來控制刷臟頁的速度。

所以無論是在查詢,需要加載數(shù)據(jù)到內(nèi)存數(shù)據(jù)頁,而淘汰臟頁。還是更新時(shí),導(dǎo)致刷盤操作都有可能造成 MySQL 的性能下降。

為了避免這種情況,要合理的設(shè)置 innodb_io_capacity 的值,平時(shí)要多關(guān)注臟頁比例,不讓其接近 75%.

其中臟頁比例可以通過下面的方式獲取:

mysql> use performance_schema;
mysql> select VARIABLE_VALUE into @a from global_status where VARIABLE_NAME = 'Innodb_buffer_pool_pages_dirty';
select VARIABLE_VALUE into @b from global_status where VARIABLE_NAME = 'Innodb_buffer_pool_pages_total';
select @a/@b;

初次之外,在一個(gè)查詢操作進(jìn)行時(shí),如果需要 flush 臟頁的話,如果這個(gè)該臟頁的鄰居也是臟頁的話,就會(huì)把這個(gè)鄰居一起刷掉,如果恰好旁邊還是臟頁的話,就會(huì)一直連坐。這時(shí)導(dǎo)致 flush 過慢的原因。

可以通過 innodb_flush_neighbors 來控制該行為,值為 1 打開上述機(jī)制,為 0 則關(guān)閉。

對(duì)于機(jī)械硬盤來說,是可以減少很多隨機(jī) IO ,因?yàn)闄C(jī)械硬盤 IOPS 一般就幾百,減少隨機(jī) IO 就意味著性能提升。

但如果用 SSD 這類 IOPS 較高的設(shè)備,IOPS 往往不是瓶頸,關(guān)閉就好,減少 SQL 語句的響應(yīng)時(shí)間。

在 8.0 中,已經(jīng)默認(rèn)是 0 了.

總結(jié)

這篇中,主要介紹了 WAL 時(shí)的 flush 操作可能會(huì)造成 MySQL 突然的性能下降。

引起的原因一般是由于內(nèi)存不夠?qū)е碌?,進(jìn)而可以通過設(shè)置合適的 innodb_io_capacity 參數(shù),來控制 InnoDB flush 的過程。

以上就是MySQL性能突然下降的原因的詳細(xì)內(nèi)容,更多關(guān)于MySQL性能下降的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • MySQL 如何分析查詢性能
  • MySQL創(chuàng)建高性能索引的全步驟
  • MySQL性能壓力基準(zhǔn)測(cè)試工具sysbench的使用簡介
  • Mysql性能優(yōu)化之索引下推
  • Mysql索引性能優(yōu)化問題解決方案
  • MySQL性能優(yōu)化技巧分享
  • MySQL20個(gè)高性能架構(gòu)設(shè)計(jì)原則(值得收藏)
  • Mysql高性能優(yōu)化技能總結(jié)
  • 詳解GaussDB for MySQL性能優(yōu)化

標(biāo)簽:惠州 公主嶺 阿里 呼和浩特 牡丹江 沈陽 合肥 天津

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL性能突然下降的原因》,本文關(guān)鍵詞  MySQL,性能,突然,下降,的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL性能突然下降的原因》相關(guān)的同類信息!
  • 本頁收集關(guān)于MySQL性能突然下降的原因的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    成人av在线影院| 亚洲另类春色校园小说| 美女视频网站久久| 欧美一级视频精品观看| 精品在线亚洲视频| 欧美激情综合在线| 色综合激情久久| 午夜激情一区二区| 日韩精品一区二区三区视频在线观看| 精彩视频一区二区三区| 中文字幕欧美激情| 91在线观看一区二区| 亚洲一区二区三区美女| 日韩一级片网站| 国产一区在线不卡| 国产精品乱人伦一区二区| 色网站国产精品| 亚洲欧美国产77777| 丰满岳乱妇一区二区三区| 一区二区免费在线| 欧美成人三级在线| av在线一区二区三区| 亚洲成人在线观看视频| 日韩西西人体444www| 免费成人在线视频观看| 中文字幕av一区二区三区免费看| 色呦呦国产精品| 久久国产日韩欧美精品| 18欧美亚洲精品| 日韩一二三区视频| 成人午夜精品一区二区三区| 首页综合国产亚洲丝袜| 中文字幕av一区二区三区| 欧美欧美欧美欧美首页| 久久www免费人成看片高清| 亚洲男人的天堂在线aⅴ视频| 51精品国自产在线| 成人开心网精品视频| 亚洲成在线观看| 中文字幕成人在线观看| 日韩欧美国产精品| 成人av在线资源| 日韩极品在线观看| 日韩网站在线看片你懂的| 国产一区二区三区免费看| 五月天中文字幕一区二区| 久久久不卡影院| 欧美日韩国产首页在线观看| 国产一区二区精品在线观看| 亚洲第一狼人社区| 综合在线观看色| 精品不卡在线视频| 欧美男生操女生| 日本高清不卡一区| 福利一区在线观看| 九九精品视频在线看| 日韩在线观看一区二区| 一区二区三区中文字幕精品精品 | 波多野结衣精品在线| 91国偷自产一区二区三区观看| 韩国v欧美v日本v亚洲v| 日韩高清电影一区| 亚州成人在线电影| 亚洲人成网站精品片在线观看 | 国产一级精品在线| 香港成人在线视频| 中文字幕va一区二区三区| 精品人在线二区三区| 日韩欧美在线影院| 日韩欧美激情四射| 91麻豆精品国产91久久久久 | 国产欧美一区二区精品婷婷| 精品卡一卡二卡三卡四在线| 欧美剧情片在线观看| 欧洲视频一区二区| 欧美综合色免费| 在线观看国产一区二区| 色欧美片视频在线观看| 色欧美乱欧美15图片| 色婷婷综合在线| 色综合欧美在线| 色哟哟一区二区在线观看| 99精品久久99久久久久| 色8久久人人97超碰香蕉987| 亚洲大片在线观看| 亚洲人成电影网站色mp4| ...中文天堂在线一区| 自拍偷拍欧美激情| 一区二区三区高清不卡| 亚洲成人综合视频| 日本aⅴ免费视频一区二区三区| 视频一区二区三区在线| 五月综合激情网| 麻豆精品视频在线观看| 国产自产v一区二区三区c| 国产乱人伦偷精品视频免下载 | 久久品道一品道久久精品| 久久精品人人做人人综合| 欧美国产1区2区| 精品久久久网站| 欧美日韩国产另类一区| 欧亚一区二区三区| 91精品婷婷国产综合久久性色| 7777精品伊人久久久大香线蕉最新版| 4438成人网| 国产精品五月天| 亚洲永久免费av| 蜜臀av亚洲一区中文字幕| 国产乱子伦视频一区二区三区| 成人美女在线观看| 欧美性猛交一区二区三区精品| 日韩一级片在线观看| 欧美激情综合在线| 亚洲图片自拍偷拍| 国产一区二区成人久久免费影院| 风间由美一区二区三区在线观看| 国产凹凸在线观看一区二区| 色婷婷av久久久久久久| 91年精品国产| 欧美一级专区免费大片| 国产精品女主播av| 青娱乐精品在线视频| 成人免费视频一区| 91精品国产高清一区二区三区蜜臀 | 成人激情免费网站| 91.com在线观看| 亚洲欧洲www| 蜜臀av在线播放一区二区三区| 成人福利视频在线看| 欧美一卡二卡三卡四卡| 国产欧美精品一区aⅴ影院| 久久综合久久久久88| 亚洲午夜一区二区三区| 精品在线你懂的| 精品国产a毛片| 美腿丝袜在线亚洲一区| 91精品国产综合久久婷婷香蕉| 午夜精品久久久久久久99樱桃| 在线观看一区日韩| 亚洲二区视频在线| 欧美日韩精品欧美日韩精品| 亚洲aⅴ怡春院| 欧美一区二区三区啪啪| 日韩国产在线观看| 欧美tickling网站挠脚心| 黄色成人免费在线| 久久久不卡影院| 99久久99久久综合| 一区二区三区在线观看动漫| 欧美日韩中文字幕精品| 天堂va蜜桃一区二区三区| 欧美一区二区精品| 国产自产高清不卡| 国产精品的网站| 在线国产电影不卡| 日韩中文字幕区一区有砖一区| 日韩三级在线观看| 国产不卡视频一区二区三区| 国产精品久99| 欧美日韩在线三区| 日本美女一区二区| 国产日韩欧美不卡在线| 91蝌蚪国产九色| 日韩av不卡在线观看| 久久亚洲精精品中文字幕早川悠里| 成人免费视频免费观看| 亚洲激情第一区| 日韩视频中午一区| 北岛玲一区二区三区四区| 夜夜嗨av一区二区三区| 欧美大尺度电影在线| 成人不卡免费av| 无吗不卡中文字幕| 久久久久久久久一| 91女厕偷拍女厕偷拍高清| 蜜臀99久久精品久久久久久软件| 中文字幕乱码一区二区免费| 欧美日韩国产高清一区| 国产精品自拍三区| 夜夜爽夜夜爽精品视频| 久久影院视频免费| 欧美影院一区二区| 国产精品一二三| 图片区小说区区亚洲影院| 国产精品天干天干在线综合| 欧美人动与zoxxxx乱| 高清beeg欧美| 七七婷婷婷婷精品国产| 中文字幕在线免费不卡| 日韩一区二区在线观看| 91视频精品在这里| 国产一区二区三区免费观看| 亚洲综合成人网| 欧美激情一区在线观看| 日韩欧美不卡在线观看视频| 91网站最新地址| 国产美女视频一区| 日韩主播视频在线| 亚洲美女屁股眼交3| 久久久久久麻豆|