吴忠躺衫网络科技有限公司

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

磁盤I/O瓶頸的解決方法

CHANBAEK ? 來源:myfreax ? 作者:myfreax ? 2023-01-04 17:28 ? 次閱讀

如果您的Linux服務(wù)器出現(xiàn)故障,您的第一步通常是在終端中使用top命令來檢查平均負(fù)載。

但是,有時(shí)會(huì)top命令顯示非常高的平均負(fù)載,即使CPUus和CPU的id的度數(shù)比較低也是如此。

如果CPU單核的負(fù)載超過1,但CPU顯示大約70%空閑。這種情況的常見原因之一是磁盤 I/O瓶頸。

什么是I/O等待瓶頸

存儲(chǔ)I/O是物理磁盤或其他存儲(chǔ),例如磁盤或SSD。輸入/輸出(或?qū)懭?讀取)的操作。

如果CPU需要在磁盤上等待讀取或?qū)懭霐?shù)據(jù),則涉及磁盤I/O的請(qǐng)求會(huì)顯著變慢。I/O Wait是CPU必須等待存儲(chǔ)設(shè)備的時(shí)間百分比。

在Linux服務(wù)器可以使用一些終端命令行工具,例如top、atop和iotop來確認(rèn)磁盤I/O是否正在降低應(yīng)用程序性能。

top 命令平均負(fù)載與等待時(shí)間wa

當(dāng)您運(yùn)行top命令,您將首先瀏覽右上角檢查平均負(fù)載。在這種情況下,它非常高。

接下來,我們很可能會(huì)瀏覽頂部附近的CPU和內(nèi)存,然后是%CPU%MEM列,以了解哪些進(jìn)程使用的資源最多。

top,您還需要查看wa,它幾乎一直是0.0%。值始終高于1%可能表示您的存儲(chǔ)設(shè)備速度太慢,無法跟上IO的請(qǐng)求。

值得注意的是,top命令頂部%Cpu(s)行的wa是多個(gè)核心wa的平均值,可以按1鍵來展開視圖,查看每個(gè)CPU核心wa值。

完成此操作后,我們看到某些CPU內(nèi)核的%wa時(shí)間高達(dá) 60%。所以我們知道有一個(gè)主要的瓶頸,接下來我們來確認(rèn)一下這個(gè)磁盤瓶頸。

atop 命令監(jiān)控DSK(存儲(chǔ))I/O 統(tǒng)計(jì)信息

接下來,使用atop,我們看到存儲(chǔ)設(shè)備DSK行的busy的值在90%到100%。這是一個(gè)嚴(yán)重的瓶頸。在Web服務(wù)導(dǎo)致結(jié)果就是HTTP請(qǐng)求被阻塞,直到磁盤I/O可以趕上。

atop,按d鍵盤查看正在使用磁盤I/O的進(jìn)程。這里我們看到MySQL、Nginx、PHP-FPM,這些都是web服務(wù)核心進(jìn)程。

要降低web服務(wù)磁盤IO,可以考慮將Nginx或Apache、MySQL和PHP-FPM的訪問日志和錯(cuò)誤日志不要過于頻繁地寫入磁盤。

并且避免將緩存(例如Nginx 緩存)存儲(chǔ)在磁盤。高并發(fā)流量環(huán)境。除了LEMP服務(wù)之外。

還要注意flush-8:0(一個(gè)PHP緩存問題)和jbd2/sda5-8(跟蹤到訪問/內(nèi)核日志)及其進(jìn)程。

此時(shí),如果可以,你應(yīng)該在Linux服務(wù)器上執(zhí)行一個(gè)快速SSD基準(zhǔn)測(cè)試,以了解磁盤IO的速度。

運(yùn)行命令dd if=/dev/zero of=diskbench bs=1M count=1024 conv=fdatasync。

dd if=/dev/zero of=diskbench bs=1M count=1024 conv=fdatasync
1073741824 bytes (1.1 GB) copied, 46.0156 s, 23.3 MB/s

盡管可以減少讀/寫,但磁盤I/O非常慢。如果MySQL的my.cnf的max_connections設(shè)置太高。

就會(huì)導(dǎo)致MySQL連接和查詢堆積并增長(zhǎng)到超出可用服務(wù)器RAM的范圍。它就會(huì)發(fā)展到Linux內(nèi)核OOM殺死MySQL的地步。

通常MySQL最大的連接數(shù)等于最大分配內(nèi)存除以每個(gè)線程緩沖區(qū)的大小。

iotop 命令實(shí)時(shí)監(jiān)控磁盤讀/寫

iotop命令監(jiān)控Linux內(nèi)核輸出的I/O使用信息。它顯示系統(tǒng)進(jìn)程或線程的當(dāng)前I/O使用情況,運(yùn)行命令iotop -oPa

iotop -oPa

iotop命令-o選項(xiàng)僅顯示正在執(zhí)行I/O的進(jìn)程或線程,而不是顯示所有進(jìn)程或線程。這可以通過按o鍵 動(dòng)態(tài)切換。

-P選項(xiàng)僅顯示進(jìn)程。通常iotop命令顯示所有線程。-a選項(xiàng)顯示累積的I/O而不是帶寬。

在這種模式下,iotop命令顯示自iotop命令啟動(dòng)以來完成的I/O進(jìn)程的數(shù)量。

查看DISK WRITE列,這些數(shù)字不是很大。合理平均速度的存儲(chǔ)設(shè)備不會(huì)忙于一些內(nèi)核日志記錄和磁盤緩存。

但是在低于25 MB/s的寫入速度時(shí),磁盤IO就會(huì)被Nginx緩存、內(nèi)核日志、訪問日志等操作使用最大化。要解決這類問題,是用性能更好的存儲(chǔ)設(shè)備替換現(xiàn)有的設(shè)備。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11345

    瀏覽量

    210391
  • 服務(wù)器
    +關(guān)注

    關(guān)注

    12

    文章

    9303

    瀏覽量

    86061
  • 磁盤
    +關(guān)注

    關(guān)注

    1

    文章

    380

    瀏覽量

    25276
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    什么是磁盤I/O驅(qū)動(dòng)程序嗎?它的用途是什么?

    我正在閱讀有關(guān) FAT 文件系統(tǒng)組件的 Espressif 文檔。在這份文檔中,寫到 FatFS 已經(jīng)擴(kuò)展了 API 函數(shù),可以在運(yùn)行時(shí)注冊(cè)磁盤 I/O 驅(qū)動(dòng)程序。你能解釋一下什么是磁盤
    發(fā)表于 04-13 08:39

    Linux系統(tǒng)中網(wǎng)絡(luò)I/O性能改進(jìn)方法的研究

    選擇并設(shè)計(jì)高效的網(wǎng)絡(luò)I/O模型是改善服務(wù)器性能的關(guān)鍵。該文通過對(duì)Linux系統(tǒng)中幾種網(wǎng)絡(luò)I/O模型的分析和研究,提出3種改善網(wǎng)絡(luò)I/
    發(fā)表于 04-09 09:41 ?28次下載

    一種高效的磁盤隊(duì)列I/O機(jī)制

    分析了傳統(tǒng)磁盤隊(duì)列的存儲(chǔ)管理開銷和讀寫性能,針對(duì)磁盤隊(duì)列I/O已成為影響消息服務(wù)器性能的首要瓶頸,提出了一種高效
    發(fā)表于 05-14 19:51 ?32次下載

    播出服務(wù)器磁盤I/O與緩存性能分析

    播出服務(wù)器磁盤I/O與緩存性能分析:針對(duì)電視臺(tái)專業(yè)播出服務(wù)器在播出質(zhì)量和播出性能上的高要求,提出了(s,S)策略下讀數(shù)據(jù)緩存和復(fù)用緩存與節(jié)目數(shù)量、節(jié)目數(shù)據(jù)速率、磁盤性能
    發(fā)表于 01-16 15:09 ?22次下載

    I/O擴(kuò)展(8255)模塊

    為用戶在中提供一個(gè)I/O 擴(kuò)展的方法,在設(shè)計(jì)過程遇到I/O不夠用時(shí)可以用此種方案。
    發(fā)表于 07-04 17:12 ?0次下載

    Java I/O 的相關(guān)方法分析

    I/O,即 Input/Output(輸入/輸出) 的簡(jiǎn)稱。就 I/O 而言,概念上有 5 種模型:blocking I/
    發(fā)表于 09-27 13:18 ?0次下載
    Java <b class='flag-5'>I</b>/<b class='flag-5'>O</b> 的相關(guān)<b class='flag-5'>方法</b>分析

    通過對(duì)blktrace的輸出結(jié)果進(jìn)行分析讀、寫操作的磁盤塊進(jìn)行I/O頻次統(tǒng)計(jì)

    通過對(duì)blktrace的輸出結(jié)果進(jìn)行分析,我們可以對(duì)特定時(shí)間段內(nèi)發(fā)生的讀、寫操作的磁盤塊進(jìn)行I/O頻次統(tǒng)計(jì)。結(jié)合通過將磁盤I/
    的頭像 發(fā)表于 04-03 09:48 ?9705次閱讀
    通過對(duì)blktrace的輸出結(jié)果進(jìn)行分析讀、寫操作的<b class='flag-5'>磁盤</b>塊進(jìn)行<b class='flag-5'>I</b>/<b class='flag-5'>O</b>頻次統(tǒng)計(jì)

    關(guān)于I/O口位操作的方法介紹(2)

    I/O口位操作的方法
    的頭像 發(fā)表于 07-10 11:45 ?3916次閱讀
    關(guān)于<b class='flag-5'>I</b>/<b class='flag-5'>O</b>口位操作的<b class='flag-5'>方法</b>介紹(2)

    關(guān)于I/O口位操作的方法介紹(1)

    I/O口位操作的方法
    的頭像 發(fā)表于 07-02 11:17 ?4003次閱讀
    關(guān)于<b class='flag-5'>I</b>/<b class='flag-5'>O</b>口位操作的<b class='flag-5'>方法</b>介紹(1)

    如何更改 Linux 的 I/O 調(diào)度器

    Linux 的 I/O 調(diào)度器是一個(gè)以塊式 I/O 訪問存儲(chǔ)卷的進(jìn)程,有時(shí)也叫磁盤調(diào)度器。Linux I
    發(fā)表于 05-15 15:54 ?875次閱讀
    如何更改 Linux 的 <b class='flag-5'>I</b>/<b class='flag-5'>O</b> 調(diào)度器

    如何用GPUDirect存儲(chǔ)器如何緩解CPU I / O瓶頸

    的數(shù)據(jù) I / O 增長(zhǎng)成為處理時(shí)間的瓶頸。當(dāng)人工智能和數(shù)據(jù)科學(xué)繼續(xù)重新定義可能的藝術(shù)時(shí),啟用直接路徑可以減少甚至完全緩解這個(gè)瓶頸。
    的頭像 發(fā)表于 04-10 10:59 ?4235次閱讀
    如何用GPUDirect存儲(chǔ)器如何緩解CPU <b class='flag-5'>I</b> / <b class='flag-5'>O</b><b class='flag-5'>瓶頸</b>

    Linux磁盤I/O的性能指標(biāo)和查看性能工具

    在我之前的文章:《探討 Linux 的磁盤 I/O》中,我談到了 Linux 磁盤 I/O 的工
    的頭像 發(fā)表于 05-14 15:21 ?2691次閱讀

    單片機(jī)I/O驅(qū)動(dòng)與隔離常見設(shè)計(jì)方法

    單片機(jī)I/O驅(qū)動(dòng)與隔離常見設(shè)計(jì)方法
    的頭像 發(fā)表于 10-25 17:36 ?2280次閱讀
    單片機(jī)<b class='flag-5'>I</b>/<b class='flag-5'>O</b>驅(qū)動(dòng)與隔離常見設(shè)計(jì)<b class='flag-5'>方法</b>

    磁盤I/O是怎么工作的

    同前面講述的CPU、內(nèi)存一樣,文件系統(tǒng)和磁盤I/O,也是Linux操作系統(tǒng)最核心的功能。 磁盤為系統(tǒng)提供了最基本的持久化存儲(chǔ)。 文件系統(tǒng)則在磁盤
    的頭像 發(fā)表于 11-13 11:20 ?1099次閱讀
    <b class='flag-5'>磁盤</b><b class='flag-5'>I</b>/<b class='flag-5'>O</b>是怎么工作的

    FANUC外部I/O點(diǎn)數(shù)不夠用了怎么辦?可以擴(kuò)展I/O點(diǎn)數(shù)嗎?

    FANUC外部I/O點(diǎn)數(shù)不夠用了怎么辦?可以擴(kuò)展I/O點(diǎn)數(shù)嗎? 擴(kuò)展FANUC的外部I/O點(diǎn)數(shù)是
    的頭像 發(fā)表于 02-18 15:21 ?2081次閱讀
    澄江县| 百家乐长龙技巧| 牛牛现金棋牌| 百家乐三路秘诀| 垦利县| 百家乐庄闲路| 百家乐官网投注方向| 太阳百家乐网| 百家乐官网高级技巧| 德州扑克胜率| 百家乐仿水晶筹码| 百家乐赌场群| 电玩城百家乐官网技巧| 易玩棋牌怎么样| 百家乐现金投注信誉平台| 百家乐官网波音平台路单| 威尼斯人娱乐开户| 在线百家乐官网策略| 辉县市| 百家乐视频画面| 百家乐官网桌子定制| 百家乐官网交流群号| 威尼斯人娱乐城赌场| 百家乐官网五铺的缆是什么意思| 正蓝旗| 富田太阳城租房| 百家乐固定打法| 家百家乐官网破解软件| 大发888的促销代码| 百家乐庄河闲的赌法| 澳门百家乐官网国际| 帝王娱乐城开户| 如何玩百家乐赢钱技巧| 奥斯卡百家乐官网的玩法技巧和规则| 在线棋牌游戏| 免费百家乐统计工具| 百家乐玩法秘诀| 玩百家乐官网会犯法吗| 脉动棋牌下载| 百家乐博乐城| 百家乐有秘技吗|