MySQL服務器的SSD性能問題分析和測試詳解
【問題】
我們有臺HP的服務器,SSD在寫IOPS約5000時,%util達到80%以上,那么這塊SSD的性能究竟有沒有問題,為解決這個問題做了下面測試。
【工具】
blktrace是linux下用來排查IO性能的工具。它可以記錄IO經(jīng)歷的各個步驟,并計算出IO請求在各個階段的消耗,下面是關鍵的一些步驟:
Q2G – 生成IO請求所消耗的時間,包括remap和split的時間;
G2I – IO請求進入IO Scheduler所消耗的時間,包括merge的時間;
I2D – IO請求在IO Scheduler中等待的時間;
D2C – IO請求在driver和硬件上所消耗的時間;
Q2C – 整個IO請求所消耗的時間(G2I + I2D + D2C = Q2C),相當于iostat的await。
其中D2C可以作為硬件性能的指標,I2D可以作為IO Scheduler性能的指標。
【測試一、比較HP SSD Smart Path開啟前后SSD的寫入性能】
1、HP SSD Smart Path開啟,SSD控制器Caching關閉,Cache Ratio: 100% Read / 0% Write
測試結(jié)果如下,主要關注D2C(IO請求在SSD上消耗的時間)的AVG值,約為0.217ms
2、HP SSD Smart Path關閉,SSD控制器Caching開啟,Cache Ratio: 10% Read / 90% Write
測試結(jié)果如下,主要關注D2C(IO請求在SSD上消耗的時間)的AVG值,約為0.0906ms
【結(jié)論】
前者在硬件上的消耗時間是后者的約2.4倍,對于寫入為主的系統(tǒng),建議HP SSD Smart Path關閉,SSD控制器Caching開啟
【測試二、比較noop和deadline兩種I/O調(diào)度算法的性能】
目前磁盤的調(diào)度算法有如下四種,我們系統(tǒng)中的配置值為deadline,很多資料上建議SSD配置為noop
1、Anticipatory,適用于個人PC,單磁盤系統(tǒng);
2、CFQ(Complete Fair Queuing),默認的IO調(diào)度算法,完全公平的排隊調(diào)度算法
3、Deadline,按照截止期限來循環(huán)在各個IO隊列中進行調(diào)度
4、noop,簡單的FIFO隊列進行調(diào)度
下面都在HP SSD Smart Path關閉的情況下測試,
1、deadline, 主要關注G2I和I2D
2、修改為noop
【結(jié)論】
noop的IO Scheduler在等待和消耗的時間比deadline稍好,但差異不是很大。如果需要評估,還需要進一步詳細的在各個場景下的測試。
下圖是網(wǎng)上資料對不同調(diào)度算法的測試比較:
【測試三、比較這臺服務器SSD與相同配置SSD的消耗時間】
AVG D2C為0.0906ms,0.0934ms,差異不大,說明這臺服務器的SSD從響應時間上正常
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關文章
Mysql?8.4.0?結(jié)合?Docker?搭建GTID主從復制及傳統(tǒng)主從復制詳解
這篇文章主要介紹了Mysql?8.4.0?結(jié)合?Docker?搭建GTID主從復制,以及傳統(tǒng)主從復制,本文給大家講解的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2024-06-06MySQL命令提示符出現(xiàn)輸入錯誤時如何修改前面的命令
本文主要介紹了MySQL命令提示符出現(xiàn)輸入錯誤時如何修改前面的命令,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-10-10MySQL中CONCAT和GROUP_CONCAT方法的區(qū)別詳解
本文主要介紹了MySQL中CONCAT和GROUP_CONCAT方法的區(qū)別詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-01-01淺談mysql 系統(tǒng)用戶最大文件打開數(shù)限制
這篇文章主要介紹了mysql 系統(tǒng)用戶最大文件打開數(shù)限制,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-03-03