Linux效能測試UnixBench一鍵指令碼
UnixBench是一個類unix系(Unix,BSD,Linux)統下的效能測試工具,一個開源工具,被廣泛用與測試linux系統主機的效能。Unixbench的主要測試專案有:系統呼叫、讀寫、程序、圖形化測試、2D、3D、管道、運算、C庫等系統基準效能提供測試資料。
最新版本UnixBench5.1.3,包含system和graphic測試,如果你需要測試graphic,則需要修改Makefile,不要註釋掉”GRAPHIC_TESTS = defined”,同時需要系統提供x11perf命令gl_glibs庫。
下面的指令碼使用了最新版UnixBench5.1.3來測試,註釋了關於graphic的測試項(大多數VPS都是沒有顯示卡或者是集顯,所以影象效能無需測試),執行10-30分鐘後(根據CPU核心數量,運算時間不等)得出分數,越高越好。
測試方法:
測試專案:
Dhrystone 2 using register variables
此項用於測試 string handling,因為沒有浮點操作,所以深受軟體和硬體設計(hardware and software design)、編譯和連結(compiler and linker options)、程式碼優化(code optimazaton)、對記憶體的cache(cache memory)、等待狀態(wait states)、整數資料型別(integer data types)的影響。
Double-Precision Whetstone
這一項測試浮點數操作的速度和效率。這一測試包括幾個模組,每個模組都包括一組用於科學計算的操作。覆蓋面很廣的一系列 c 函式:sin,cos,sqrt,exp,log 被用於整數和浮點數的數學運算、陣列訪問、條件分支(conditional branch)和程式呼叫。此測試同時測試了整數和浮點數算術運算。
Execl Throughput
此測試考察每秒鐘可以執行的 execl 系統呼叫的次數。 execl 系統呼叫是 exec 函式族的一員。它和其他一些與之相似的命令一樣是 execve() 函式的前端。
File copy
測試從一個檔案向另外一個檔案傳輸資料的速率。每次測試使用不同大小的緩衝區。這一針對檔案 read、write、copy 操作的測試統計規定時間(預設是 10s)內的檔案 read、write、copy 操作次數。
Pipe Throughput
管道(pipe)是程序間交流的最簡單方式,這裡的 Pipe throughtput 指的是一秒鐘內一個程序可以向一個管道寫 512 位元組資料然後再讀回的次數。需要注意的是,pipe throughtput 在實際程式設計中沒有對應的真實存在。
Pipe-based Context Switching
這個測試兩個程序(每秒鐘)通過一個管道交換一個不斷增長的整數的次數。這一點很向現實程式設計中的一些應用,這個測試程式首先建立一個子程序,再和這個子程序進行雙向的管道傳輸。
Process Creation
測試每秒鐘一個程序可以建立子程序然後收回子程序的次數(子程序一定立即退出)。process creation 的關注點是新程序程序控制塊(process control block)的建立和記憶體分配,即一針見血地關注記憶體頻寬。一般說來,這個測試被用於對作業系統程序建立這一系統呼叫的不同實現的比較。
System Call Overhead
測試進入和離開作業系統核心的代價,即一次系統呼叫的代價。它利用一個反覆地呼叫 getpid 函式的小程式達到此目的。
Shell Scripts
測試一秒鐘內一個程序可以併發地開始一個 shell 指令碼的 n 個拷貝的次數,n 一般取值 1,2,4,8。(我在測試時取 1, 8)。這個指令碼對一個數據檔案進行一系列的變形操作(transformation)。
下面是我的一個512MB,2核,OpenVZ的VPS的跑分結果: