linux sysbench (一): CPU性能测试详解

简介:

1.sysbench基础知识

sysbench的cpu测试是在指定时间内,循环进行素数计算

素数(也叫质数)就是从1开始的自然数中,无法被整除的数,比如2、3、5、7、11、13、17等。编程公式:对正整数n,如果用2到根号n之间的所有整数去除,均无法整除,则n为素数。

2.sysbench安装

 
  1. # CentOS7下可使用yum安装

  2. yum install sysbench

3.CPU压测命令

 
  1. # 默认参数,素数上限10000,时间10秒,单线程

  2. sysbench cpu run

4.常用参数

--cpu-max-prime: 素数生成数量的上限

 
  1. - 若设置为3,则表示235(这样要计算1-55次)

  2. - 若设置为10,则表示2357111317192329(这样要计算1-2929次)

  3. - 默认值为10000

--threads: 线程数

 
  1. - 若设置为1,则sysbench仅启动1个线程进行素数的计算

  2. - 若设置为2,则sysbench会启动2个线程,同时分别进行素数的计算

  3. - 默认值为1

--time: 运行时长,单位秒

 
  1. - 若设置为5,则sysbench会在5秒内循环往复进行素数计算,

  2. 从输出结果可以看到在5秒内完成了几次,

  3. 比如配合--cpu-max-prime=3,则表示第一轮算得3个素数,

  4. 如果时间还有剩就再进行一轮素数计算,直到时间耗尽。

  5. 每完成一轮就叫一个event

  6. - 默认值为10

  7. - 相同时间,比较的是谁完成的event

--events: event上限次数

 
  1. - 若设置为100,则表示当完成100event后,即使时间还有剩,也停止运行

  2. - 默认值为0,则表示不限event次数

  3. - 相同event次数,比较的是谁用时更少

5.案例结果分析

执行命令

 
  1. # 素数上限2万,时间10秒,2个线程

  2. sysbench cpu --cpu-max-prime=20000 --threads=2 run

结果分析

 
  1. sysbench 1.0.9 (using system LuaJIT 2.0.4)

  2. Running the test with following options:

  3. Number of threads: 2 // 指定线程数为2

  4. Initializing random number generator from current time

  5. Prime numbers limit: 20000 // 每个线程产生的素数上限均为2万个

  6. Initializing worker threads...

  7. Threads started!

  8. CPU speed:

  9. events per second: 650.74 // 所有线程每秒完成了650.74次event

  10. General statistics:

  11. total time: 10.0017s // 共耗时10秒

  12. total number of events: 6510 // 10秒内所有线程一共完成了6510次event

  13. Latency (ms):

  14. min: 3.03 // 完成1次event的最少耗时3.03秒

  15. avg: 3.07 // 所有event的平均耗时3.07毫秒

  16. max: 3.27 // 完成1次event的最多耗时3.27毫秒

  17. 95th percentile: 3.13 // 95%次event在3.13秒毫秒内完成

  18. sum: 19999.91 // 每个线程耗时10秒,2个线程叠加耗时就是20秒

  19. Threads fairness:

  20. events (avg/stddev): 3255.0000/44.00 // 平均每个线程完成3255次event,标准差为44

  21. execution time (avg/stddev): 10.0000/0.00 // 每个线程平均耗时10秒,标准差为0

event: 完成了几轮的素数计算

stddev(标准差): 在相同时间内,多个线程分别完成的素数计算次数是否稳定,如果数值越低,则表示多个线程的结果越接近(即越稳定)。该参数对于单线程无意义。

6.结果分析

如果有2台服务器进行CPU性能对比,当素数上限和线程数一致时:

 ●   相同时间,比较event
 ●   相同event,比较时间
 ●   时间和event都相同,比较stddev(标准差)

原文发布时间为:2018-09-15
本文作者:陈承
本文来自云栖社区合作伙伴“ 老叶茶馆”,了解相关信息可以关注“ 老叶茶馆”。
相关文章
|
Oracle 关系型数据库 MySQL
Oracle Linux 8.10 编译安装sysbench
Oracle Linux 8.10 编译安装sysbench
499 34
|
运维 Linux 虚拟化
Linux 查看 CPU 使用情况
在 Linux 系统中,查看 CPU 使用情况是性能分析和故障排查的重要环节。查看 CPU 使用情况,使用 top 命令或者 htop 命令来查看。
|
缓存 监控 Linux
在Linux中,如何看当前系统有几颗物理CPU和每颗CPU的核数?
在Linux中,如何看当前系统有几颗物理CPU和每颗CPU的核数?
|
Ubuntu Linux 应用服务中间件
Linux使用cpulimit对CPU使用率进行限制
cpulimit是一款简单易用的CPU使用率限制工具,支持对特定程序或整个CPU使用率进行限制。可通过源安装(如`yum`或`apt-get`)或编译安装获取。使用时,可针对程序名、进程号或绝对路径设置CPU占用上限(如`cpulimit -e xmrig -l 60 -b`)。ROOT用户可限制所有进程,普通用户仅限于权限范围内进程。注意,CPU百分比基于实际核心数(单核100%,双核200%,依此类推)。
1777 7
|
存储 缓存 Linux
Linux系统中如何查看CPU信息
本文介绍了查看CPU核心信息的方法,包括使用`lscpu`命令和读取`/proc/cpuinfo`文件。`lscpu`能快速提供逻辑CPU数量、物理核心数、插槽数等基本信息;而`/proc/cpuinfo`则包含更详细的配置数据,如核心ID和处理器编号。此外,还介绍了如何通过`lscpu`和`dmidecode`命令获取CPU型号、制造商及序列号,并解释了CPU频率与缓存大小的相关信息。最后,详细解析了`lscpu`命令输出的各项参数含义,帮助用户更好地理解CPU的具体配置。
1775 8
|
缓存 安全 Linux
Linux系统查看操作系统版本信息、CPU信息、模块信息
在Linux系统中,常用命令可帮助用户查看操作系统版本、CPU信息和模块信息
3799 23
|
缓存 监控 Linux
|
关系型数据库 MySQL 测试技术
【赵渝强老师】MySQL的基准测试与sysbench
本文介绍了MySQL数据库的基准测试及其重要性,并详细讲解了如何使用sysbench工具进行测试。内容涵盖sysbench的安装、基本使用方法,以及具体测试MySQL数据库的步骤,包括创建测试数据库、准备测试数据、执行测试和清理测试数据。通过这些步骤,可以帮助读者掌握如何有效地评估MySQL数据库的性能。
648 5
|
缓存 运维 Linux
深入探索Linux内核:CPU拓扑结构探测
【10月更文挑战第18天】在现代计算机系统中,CPU的拓扑结构对性能优化和资源管理至关重要。了解CPU的核心、线程、NUMA节点等信息,可以帮助开发者和系统管理员更好地调优应用程序和系统配置。本文将深入探讨如何在Linux内核中探测CPU拓扑结构,介绍相关工具和方法。
514 0