作者/来源:新睿云小编 发布时间:2019-11-25
本文所有操作对应的是 Debian 系统,并且用户假设为 root 用户。主要针对新睿云的云服务器进行了性能测试,对于测试设备安装,调试使用均有涉猎,可以让用户选择到最靠谱的云服务器。
云服务器
在开始测试云服务器之前,推荐按量计费方式购买实例。同时确保用于对比的云服务器配置规格相同或具有可比性。
通过服务商提供的账户名和密码登陆新睿云服务器之后,请先更新系统(本文所有操作均针对 Debian 系统)。
apt-get update
在云服务器的测试过程,我将先通过 UnixBench 和 GeekBench 这两个常用的基准测试工具,获得对主机的一个总体评分。然后再从 CPU、内存和磁盘 I/O 等方面进行单项测试。
1. UnixBench
UnixBench 是测试类 Unix 系统性能的老牌工具,也是常用的基准测试工具。它会执行 11 个单项测试,包括字符串处理、浮点运算效率、 文件数据传输、管道吞吐等,然后将结果与一个基准系统进行比较,得到一个指数值。指数值越高,性能越好。
最终的得分比单个测试的结果根据参考价值,而且也方便对服务器进行比较。
在安装 UnixBench 之前,要先准备好相关的依赖。请执行:
apt-get install libx11-dev libgl1-mesa-dev libxext-dev perl perl-modules make gcc
下载安装包,然后按下面的提示操作。官方的源在 googlecode 上,国内访问不便,我已经将文件上传到对象存储服务。
wget http://codingpy-1252715393.cosgz.myqcloud.com/archive/UnixBench5.1.3.tgz
tar xvf UnixBench5.1.3.tgz
cd UnixBench
make
运行 make 之前,确保将 Makefile 文件中 GRAPHICS_TEST = defined 行被注释掉,因为我们是在服务器端进行测试,不需要做 2D/3D 图形测试。
最后,执行:
./Run
如果一切正常,应该会出现类似下面的文字:
UnixBench 运行
UnixBench 测试的运行时间比较长,期间可以离开去干别的事情。
除了直接在命令行输出测试结果之外(如下图),还会在 result 目录下生成一个 HTML 格式的报告,可以将其拷贝至本地。
UnixBench 测试结果
一般来说,得分在 1000 以上的云服务器就算还不错的。
2. GeekBench
GeekBench 是另一款知名的性能测试工具,目前的最新版本为 GeekBench 4。相较于 GeekBench 3,最新版对测试标准进行了调整,能够更好地模拟真实任务和应用。它支持测试单核和多核性能,不过由于我们选择的虚拟机只有 1 核,在测试时请忽略多核的测试得分。
还要注意的是,GeekBench 是一款商业软件,可供免费使用的只有 32 位。如果你想在 64 位服务器上使用该工具,则需先添加必备的运行时库。
dpkg --add-architecture i386
apt-get update
apt-get install libc6:i386 libstdc++6:i386
然后下载安装包:
wget http://codingpy-1252715393.cosgz.myqcloud.com/archive/Geekbench-4.0.0-Linux.tar.gz ~/ # 官方地址下载较慢,替换为国内源。
解压缩并执行测试:
tar -zxvf ~/Geekbench-4.0.0-Linux.tar.gz && cd ~/build.pulse/dist/Geekbench-4.0.0-Linux/
./geekbench_x86_64
测试结束后,GeekBench 会将结果上传到自己的网站,并返回一个访问链接。
3. CPU Cyclictest
Cyclictest 是一个高精度测试程序,可用来衡量 CPU 的平均延迟,即完成一个 CPU 周期所需的时间。通过这个数据,我们可以判断物理 CPU 的超卖情况;特定时间内,有多少虚拟 CPU 在排队等候物理 CPU 进行处理。因此,这个测试的数据越低,说明 CPU 的响应越快,延迟越低。
cyclictest 是 rt-tests 包的一部分,我们按如下操作安装并运行:
apt-get install rt-tests
cyclictest -D 10s -q
我们将使用测试结果中的 avg_lat 值。
4. 内存性能
Mbw 是一个 Linux 内存性能测试工具,可以测试内存数据拷贝操作的速度。速度越快,性能越高。在内存大小相同的情况下,该指标就显得比较重要,该指标越高越好。因为通常内存数据操作是计算的常见瓶颈之一。
按如下操作安装并运行:
apt-get install mbw
mbw -n 250 -t 0 200
我们取测试结果中 avg_copy 的值。
5. 磁盘 I/O
磁盘 I/O 也是云服务器性能的重要指标,一般是选择读写速度快的。磁盘 I/O 性能测试主要分为两类:顺序读写和随机读写。顺序读写频繁,应该关注数据吞吐量指标;随机读写频繁,核心指标则是 IOPS,即每秒的输入输出量(或读写次数)。我们的云服务器上主要是存储一些小文件,更注重随机读写性能。
Fio 是测试磁盘 I/O 的传统基准工具。安装非常简单:
apt-get install fio
使用如下命令测试磁盘随机读性能:
fio --name=randread --ioengine=libaio --direct=1 --bs=4k --iodepth=64 --size=4G --rw=randread --gtod_reduce=1
部分选项的说明如下:
direct=1:测试过程绕过机器自带的 buffer,使测试结果更加真实。
rw=randread:测试随机读的 I/O
size=4G:本次测试文件的大小为 4G
bs=4k:单次 I/O 的块文件大小为 4KB
iodepth=64:一次执行 64 个操作。
使用如下命令测试磁盘随机写性能:
fio --name=randwrite --ioengine=libaio --direct=1 --bs=4k --iodepth=64 --size=4G --rw=randwrite --gtod_reduce=1
IOPS 的值越高,磁盘读写性能越好。
磁盘性能的另一个指标是延迟。可以通过 IOPing 工具进行测试。IOPing 会运行指定数量的磁盘 I/O 请求,并测试响应的时间。输出结果测试使用 ping 命令测试网络延迟的输出。
操作如下提示安装 IOPing:
wget https://launchpad.net/ubuntu/+archive/primary/+files/ioping_0.9-2_i386.deb ~/
dpkg -i ~/ioping_0.9-2_i386.deb
然后通过下面的命令运行测试:
ioping -c 10 .
输出结果类似下面这样,我们取其中 avg 对应的值。
4 KiB from . (ext3 /dev/vda1): request=1 time=1.87 ms
4 KiB from . (ext3 /dev/vda1): request=2 time=1.57 ms
4 KiB from . (ext3 /dev/vda1): request=3 time=2.02 ms
4 KiB from . (ext3 /dev/vda1): request=4 time=1.78 ms
4 KiB from . (ext3 /dev/vda1): request=5 time=1.79 ms
4 KiB from . (ext3 /dev/vda1): request=6 time=1.56 ms
4 KiB from . (ext3 /dev/vda1): request=7 time=2.14 ms
4 KiB from . (ext3 /dev/vda1): request=8 time=1.96 ms
4 KiB from . (ext3 /dev/vda1): request=9 time=2.64 ms
4 KiB from . (ext3 /dev/vda1): request=10 time=1.69 ms
--- . (ext3 /dev/vda1) ioping statistics ---
10 requests completed in 9.02 s, 525 iops, 2.05 MiB/s
min/avg/max/mdev = 1.56 ms / 1.90 ms / 2.64 ms / 303 us
请求响应时间越低,说明磁盘性能越好。