磁碟IO的概念

2021-08-11 02:58:13 字數 390 閱讀 1490

讀/寫io,最為常見說法,讀io,就是發指令,從磁碟讀取某段扇區的內容。指令一般是通知磁碟開始扇區位置,然後給出需要從這個初始扇區往後讀取的連續扇區個數,同時給出動作是讀,還是寫。磁碟收到這條指令,就會按照指令的要求,讀或者寫資料。控制器發出的這種指令+資料,就是一次io,讀或者寫。

提公升磁碟io的另外乙個技巧,一次盡可能多寫入或多讀取。也就是說,將程式的讀寫buffer設定得盡可能大一些。例如日誌或者redo log的寫入,不是每次呼叫都直接寫磁碟,而是先快取到記憶體中,等buffer滿了再寫入磁碟,也可以定時寫入磁碟。

作業系統和c庫函式通常會對寫入的檔案內容做快取,以減少實際寫檔案的次數。直接呼叫系統函式fsync或c函式fflush將使系統的快取機制失效,此時將強制把內容刷到磁碟上。除非必需,否則不要執行強制刷盤操作。

磁碟 I O 的概念

i o 的概念,從字義來理解就是輸入輸出。作業系統從上層到底層,各個層次之間均存在 i o。比如,cpu 有 i o,記憶體有 i o,vmm 有 i o,底層磁碟上也有 i o,這是廣義上的 i o.通常來講,乙個上層的 i o 可能會產生針對磁碟的多個 i o,也就是說,上層的 i o 是稀疏的...

磁碟 I O 效能

如果將 sql server 配置成僅包含幾個千兆位元組 gb 的資料,且不承擔繁重的讀或寫活動,便沒有太大的必要關注磁碟 i o 主題,以及在硬碟之間平衡 sql server i o 活動以獲取最佳效能。但是要建立包含成百上千 gb 位元組的資料且 或承擔繁重的讀和 或寫活動的大型 sql se...

監控磁碟IO

需求 阿里雲的機器,今天收到客服來的 說伺服器的磁碟io很重。於是登入到伺服器檢視,並沒有發現問題,所以懷疑是間歇性地。正要考慮寫個指令碼的時候,幸運的抓到了乙個線索,造成磁碟io很高的幕後 是mysql。此時去show processlist,但未發現有問題的佇列。原來只是一瞬間。只好繼續來寫指令...