一只负壳前行的蜗牛

使用Unixbench5.1.3 来测试分析Linux云主机的性能

Unixbench是什么?

UnixBench是一个类unix系(Unix,BSD,Linux)统下的性能测试工具,一个开源工具,被广泛用与测试linux系统主机的性能。Unixbench的主要测试项目有:系统调用、读写、进程、图形化测试、2D、3D、管道、运算、C库等系统基准性能提供测试数据。

2019年最新版本UnixBench5.1.3,包含system和graphic测试,如果你需要测试graphic,则需要修改Makefile,不要注释掉”GRAPHIC_TESTS = defined”,同时需要系统提供x11perf命令gl_glibs库。
下面的脚本使用了最新版UnixBench5.1.3来测试,注释了关于graphic的测试项(大多数云主机都是没有显卡或者是集显,所以图像性能无需测试),运行10-30分钟后(根据CPU内核数量,运算时间不等)得出分数,越高越好。

下载地址:
https://github.com/kdlucas/byte-unixbench

Unixbench安装

yum -y install gcc gcc-c autoconf gcc-c++ time
wget https://storage.googleapis.com/google-code-archive-downloads/v2/code.google.com/byte-unixbench/unixbench-5.1.3.tgz
也可以#git clone https://github.com/kdlucas/byte-unixbench
tar xzf unixbench-5.1.3.tgz
cd unixbench-5.1.3

默认unixbench只支持到16cores,修改参数,取消此限制

sed -i "s/GRAPHIC_TESTS = defined/#GRAPHIC_TESTS = defined/g" ./Makefile
make;
sed -i "s/\"System Benchmarks\", 'maxCopies' => 16/\"System Benchmarks\", 'maxCopies' => 0/" Run
sed -i 's/$copies > $maxCopies/$maxCopies > 0 \&\& $copies > $maxCopies/' Run
for i in `seq 1 5`;do ./Run ;done

 

Unixbench测试项目得分说明

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)。

常见问题

问题一:安装unixbench提示: Can’t locate Time/HiRes.pm解决方法

若安装unixbench工具时提示以下错误:
Can’t locate Time/HiRes.pm in @INC (@INC contains: /usr/local/lib64/perl5 /usr/local/share/perl5 /usr/lib64/perl5/vendor_perl /usr/share/perl5/vendor_perl /usr/lib64/perl5 /usr/share/perl5 .) at ./Run line 6. BEGIN failed–compilation aborted at ./Run line 6.
可能系统缺少“HiRes.pm”组件,或程序路径问题。

解决方法如下:

“.pm”实际上是Perl的包,只需安装对应的软件包。代码如下:

yum install -y perl-Time-HiRes

安装成功即可。

问题二:如执行./Run命令后,出现如下错误。代码如下:

gcc -o ./pgms/ubgears -DTIME -Wall -pedantic -ansi -O2 -fomit-frame-pointer -fforce-addr -ffast-math -Wall ./src/ubgears.c -lGL -lXext -lX11
./src/ubgears.c:51:19: error: GL/gl.h: No such file or directory
./src/ubgears.c:52:20: error: GL/glx.h: No such file or directory
./src/ubgears.c:129: error: expected ‘=’, ‘,’, ‘;’, ‘asm’ or ‘__attribute__’ before ‘view_rotx’
…省略
./src/ubgears.c:632: error: ‘GL_RENDERER’ undeclared (first use in this function)
./src/ubgears.c:633: error: ‘GL_VERSION’ undeclared (first use in this function)
./src/ubgears.c:634: error: ‘GL_VENDOR’ undeclared (first use in this function)
./src/ubgears.c:635: error: ‘GL_EXTENSIONS’ undeclared (first use in this function)
./src/ubgears.c:643: warning: implicit declaration of function ‘glXDestroyContext’
make: *** [pgms/ubgears] Error 1</p> <p>**********************************************
Run: “make all” failed; aborting

基本上是少安装了两个图形库导致的,在Debian下,执行如下命令安装完即可。代码如下:

apt-get install libxext-dev libgl1-mesa-dev

使用centos,可执行如下命令解决此问题。代码如下:

yum install -y SDL-devel mesa-libGL-devel
点赞