首页
/
每日頭條
/
生活
/
内存性能在哪裡測試
内存性能在哪裡測試
更新时间:2026-06-14 11:58:17

一台服務器,不管是物理機還是虛拟機,必不可少的就是内存,内存的性能又是如何來衡量呢。

1. 内存與緩存

現在比較新的CPU一般都有三級緩存,L1 Cache(32KB-256KB),L2 Cache(128KB-2MB),L3 Cache(1M-32M)。緩存逐漸變大,CPU在取數據的時候,優先從緩存去取數據,取不到才去内存取數據。

内存性能在哪裡測試(内存性能的正确解讀)1

2. 内存與時延

顯然,越靠近CPU,取數據的速度越塊,通過LMBench進行了讀數延遲的測試。

内存性能在哪裡測試(内存性能的正确解讀)2

從上圖可以看出:

  1. Intel(R) Xeon(R) Platinum 8163 CPU @ 2.50GHz 這款CPU的L1D Cache,L1I Cache為32KB,而L2 Cache為1M,L3為32M;
  2. 在對應的Cache中,時延是穩定的;
  3. 不同緩存的時延呈現指數級增長;

所以我們在寫業務代碼的時候,如果想要更快地提高效率,那麼使得計算更加貼近CPU則可以獲取更好的性能。但是從上圖也可以看出,内存的時延都是納秒為單位,而實際業務中都是毫秒為單位,優化的重點應該是那些以毫秒為單位的運算,而内存時延優化這塊則是長尾部分。

3. 内存帶寬

内存時延與緩存其實可謂是緊密相關,不理解透徹了,則可能測的是緩存時延。同樣測試内存帶寬,如果不是正确的測試,則測的是緩存帶寬了。

為了了解内存帶寬,有必要去了解下内存與CPU的架構,早期的CPU與内存的架構還需要經過北橋總線,現在CPU與内存直接已經不需要北橋,直接通過CPU的内存控制器(IMC)進行内存讀取操作:

内存性能在哪裡測試(内存性能的正确解讀)3

那對應的内存帶寬是怎樣的呢?測試内存帶寬有很多很多工具,linux下一般通過stream進行測試。簡單介紹下stream的算法:

内存性能在哪裡測試(内存性能的正确解讀)4

stream算法的原理從上圖可以看出非常簡單:某個内存塊之間的數據讀取出來,經過簡單的運算放入另一個内存塊。那所謂的内存帶寬:内存帶寬=搬運的内存大小/耗時。通過整機合理的測試,可以測出來内存控制器的帶寬。下圖是某雲産品的内存帶寬數據:

------------------------------------------------------------- Function Best Rate MB/s Avg time Min time Max time Copy: 128728.5 0.134157 0.133458 0.136076 Scale: 128656.4 0.134349 0.133533 0.137638 Add: 144763.0 0.178851 0.178014 0.181158 Triad: 144779.8 0.178717 0.177993 0.180214 -------------------------------------------------------------

内存帶寬的重要性自然不言而喻,這意味着操作内存的最大數據吞吐量。但是正确合理的測試非常重要,有幾個注意事項需要關注:

  1. 内存數組大小的設置,必須要遠大于L3 Cache的大小,否則就是測試緩存的吞吐性能;
  2. CPU數目很有關系,一般來說,一兩個核的計算能力,是遠遠到不了内存帶寬的,整機的CPU全部運行起來,才可以有效地測試内存帶寬。當然跑單核的stream測試也有意義,可以測試内存的延時。
4. 其他
  1. 内存與NUMA的關系:開啟NUMA,可以有效地提供内存的吞吐性能,降低内存時延。
  2. stream算法的編譯方法選擇:通過icc編譯,可以有效地提供内存帶寬性能分。原因是Intel優化了CPU的指令,通過指令向量化和指令Prefetch操作,加速了數據的讀寫操作以及指令操作。當然其他C代碼都可以通過icc編譯的方法,提供指令的效率。

作者:ecs西邪

,
Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
科目二s彎技巧看點位置有哪些?
科目二s彎技巧看點位置有哪些?
保持全程一擋行駛,打方向不可過急;進入彎道後盡量走大圈,駛向右彎道時,右輪緊貼着右邊路邊緣線;處于彎道時,通過轉向盤讓汽車内側車蓋頭上的小後視鏡始終處于外側白線邊緣;根據路彎的特點和後輪半徑及時調整方向。曲線行駛的訓練目的是培養機動車駕駛人轉向的運用及對車輪軌迹運行的掌握技能。了解曲線行駛的路線圖是...
2026-06-14
實用家居清潔技巧:蘸牛奶擦木制家具
實用家居清潔技巧:蘸牛奶擦木制家具
實用家居清潔技巧:蘸牛奶擦木制家具實用家居清潔技巧1、用鹽去地毯上的湯汁有小孩的家庭,地毯上常常滴有湯汁,千萬不能用濕布去擦。應先後用潔淨的幹布或手巾吸幹水分,然後在污漬處撒些食鹽,待鹽面滲入吸收後,用吸塵器将鹽吸走,再用刷子整平地毯即可。2、蘸牛奶擦木制家具取一塊幹淨的抹布在過期不能飲用的牛奶裡浸...
2026-06-14
二月二的風俗有哪些?
二月二的風俗有哪些?
南方部分地區有祭社習俗,即慶祝土地公生日;北方則有吃豬頭肉、理發(剪“龍頭”)的習俗。根據民間傳說,此為主管雲雨的龍王擡頭之日,意味着在此之後雨水會漸多;民間亦有“二月二,龍擡頭”的諺語,表示春季來臨,萬物複蘇,蟄龍開始活動,預示一年的農事活動即将開始。龍擡頭(農曆二月二),又稱“春耕節”“農事節”...
2026-06-14
三伏天用什麼排濕氣寒氣最好?
三伏天用什麼排濕氣寒氣最好?
01伏天去濕氣寒氣的辦法:1、少吃甜、膩的食物。如果你身體有濕氣少吃甜膩食物,因為甜膩容易轉化為濕氣。2、别吃生冷食物。3、别喝酒。4、可以多吃姜去寒濕。5、可以多吃綠豆、西瓜、扁豆來去濕寒氣。三伏天是一年中最熱的時候,這段時間也是冬病夏治的好時候,非常适合排除體内的寒濕,伏天去濕氣寒氣的辦法:1、...
2026-06-14
漲潮退潮時間是怎樣的?
漲潮退潮時間是怎樣的?
如果是規則的半日潮,漲潮、落潮的時間是每12個小時為一個周期潮水進行漲退。可運用公式:最高潮時間=農曆*0.8,算出最高潮時間,再用公式:最低潮時間=最高潮時間+/-6,比如農曆十五或三十,漲潮時間就是12點和零點,落潮時間就是早晚的6點。由于海水的漲潮退潮是受到月球引力影響而産生的一種地理現象,因...
2026-06-14
Copyright 2023-2026 - www.tftnews.com All Rights Reserved