精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

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

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

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

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

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

什么是I/O等待瓶頸

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

如果CPU需要在磁盤上等待讀取或寫入數據,則涉及磁盤I/O的請求會顯著變慢。I/O Wait是CPU必須等待存儲設備的時間百分比。

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

top 命令平均負載與等待時間wa

當您運行top命令,您將首先瀏覽右上角檢查平均負載。在這種情況下,它非常高。

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

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

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

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

atop 命令監控DSK(存儲)I/O 統計信息

接下來,使用atop,我們看到存儲設備DSK行的busy的值在90%到100%。這是一個嚴重的瓶頸。在Web服務導致結果就是HTTP請求被阻塞,直到磁盤I/O可以趕上。

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

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

并且避免將緩存(例如Nginx 緩存)存儲在磁盤。高并發流量環境。除了LEMP服務之外。

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

此時,如果可以,你應該在Linux服務器上執行一個快速SSD基準測試,以了解磁盤IO的速度。

運行命令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設置太高。

就會導致MySQL連接和查詢堆積并增長到超出可用服務器RAM的范圍。它就會發展到Linux內核OOM殺死MySQL的地步。

通常MySQL最大的連接數等于最大分配內存除以每個線程緩沖區的大小。

iotop 命令實時監控磁盤讀/寫

iotop命令監控Linux內核輸出的I/O使用信息。它顯示系統進程或線程的當前I/O使用情況,運行命令iotop -oPa

iotop -oPa

iotop命令-o選項僅顯示正在執行I/O的進程或線程,而不是顯示所有進程或線程。這可以通過按o鍵 動態切換。

-P選項僅顯示進程。通常iotop命令顯示所有線程。-a選項顯示累積的I/O而不是帶寬。

在這種模式下,iotop命令顯示自iotop命令啟動以來完成的I/O進程的數量。

查看DISK WRITE列,這些數字不是很大。合理平均速度的存儲設備不會忙于一些內核日志記錄和磁盤緩存。

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

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • Linux
    +關注

    關注

    87

    文章

    11230

    瀏覽量

    208935
  • 服務器
    +關注

    關注

    12

    文章

    9024

    瀏覽量

    85187
  • 磁盤
    +關注

    關注

    1

    文章

    367

    瀏覽量

    25178
收藏 人收藏

    評論

    相關推薦

    什么是磁盤I/O驅動程序嗎?它的用途是什么?

    我正在閱讀有關 FAT 文件系統組件的 Espressif 文檔。在這份文檔中,寫到 FatFS 已經擴展了 API 函數,可以在運行時注冊磁盤 I/O 驅動程序。你能解釋一下什么是磁盤
    發表于 04-13 08:39

    Linux系統中網絡I/O性能改進方法的研究

    選擇并設計高效的網絡I/O模型是改善服務器性能的關鍵。該文通過對Linux系統中幾種網絡I/O模型的分析和研究,提出3種改善網絡I/
    發表于 04-09 09:41 ?28次下載

    一種高效的磁盤隊列I/O機制

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

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

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

    I/O擴展(8255)模塊

    為用戶在中提供一個I/O 擴展的方法,在設計過程遇到I/O不夠用時可以用此種方案。
    發表于 07-04 17:12 ?0次下載

    Java I/O 的相關方法分析

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

    通過對blktrace的輸出結果進行分析讀、寫操作的磁盤塊進行I/O頻次統計

    通過對blktrace的輸出結果進行分析,我們可以對特定時間段內發生的讀、寫操作的磁盤塊進行I/O頻次統計。結合通過將磁盤I/
    的頭像 發表于 04-03 09:48 ?9576次閱讀
    通過對blktrace的輸出結果進行分析讀、寫操作的<b class='flag-5'>磁盤</b>塊進行<b class='flag-5'>I</b>/<b class='flag-5'>O</b>頻次統計

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

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

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

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

    如何更改 Linux 的 I/O 調度器

    Linux 的 I/O 調度器是一個以塊式 I/O 訪問存儲卷的進程,有時也叫磁盤調度器。Linux I
    發表于 05-15 15:54 ?836次閱讀
    如何更改 Linux 的 <b class='flag-5'>I</b>/<b class='flag-5'>O</b> 調度器

    如何用GPUDirect存儲器如何緩解CPU I / O瓶頸

    的數據 I / O 增長成為處理時間的瓶頸。當人工智能和數據科學繼續重新定義可能的藝術時,啟用直接路徑可以減少甚至完全緩解這個瓶頸
    的頭像 發表于 04-10 10:59 ?4125次閱讀
    如何用GPUDirect存儲器如何緩解CPU <b class='flag-5'>I</b> / <b class='flag-5'>O</b><b class='flag-5'>瓶頸</b>

    Linux磁盤I/O的性能指標和查看性能工具

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

    AN036 基于EEPROM通信的I2C總線鎖死解決方法

    AN036 基于EEPROM通信的I2C總線鎖死解決方法
    發表于 02-23 19:09 ?0次下載
    AN036 基于EEPROM通信的<b class='flag-5'>I</b>2C總線鎖死<b class='flag-5'>解決方法</b>

    單片機I/O驅動與隔離常見設計方法

    單片機I/O驅動與隔離常見設計方法
    的頭像 發表于 10-25 17:36 ?2173次閱讀
    單片機<b class='flag-5'>I</b>/<b class='flag-5'>O</b>驅動與隔離常見設計<b class='flag-5'>方法</b>

    磁盤I/O是怎么工作的

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