Unixbench控制脚本源码分析

简介: Unixbench是一款用于linux系统的系统性能测试工具。本文是对Unixbench入口脚本Run进行分析。

Unixbench是一款用于linux系统的系统性能测试工具。本文是对Unixbench入口脚本Run进行分析。

此处由于阿里云对markdown语法和latex语法支持的不全,所以附上segmentfault上的文章链接。
https://segmentfault.com/a/1190000023799317

一、执行调用关系

unixbench 控制脚本分析-1 (Small).png

二、单测试项结果分析(结果处理为Run中的combinePassResults函数)

  1. 指定单测试项运行遍数(run pass num),通过变量testParams中的repeat参数指定:

| 命名 | 次数 | 说明 |
| ------ | ---- | ---- |
| short | 3 | 默认 |
| long | 10 | 最大 |
| single | 1 | 最小 |

  1. 先根据每一遍的结果进行排序,去掉最差的1/3的结果,可通过log文件查看:dump score为舍去的结果,Count score为参与算分的结果。
  2. 每一项原始结果,形如:COUNT|x|y|z 其中x为分数,y为时间单位,若y为0则x代表比率,z为标签符号。
  3. 当y为时间单位时的计算公式:

$$ \LARGE{score=e^{(\sum\limits_{i=1}^{iterations}\log(\frac {count\cdot timebase}{time}))/iterations}} $$

  • score: 单项分数
  • iterations:剩余有效结果的个数
  • count:每个有效结果的值
  • timebase:时间基本单位
  • time:运行的总时间

当y为0时的计算公式:

$$ \LARGE{score=e^{(\sum\limits_{i=1}^{iterations}\log(count))/iterations}} $$

三、总分结果分析(结果处理为Run中的indexResults函数)

  1. index值计算公式:

$$ \LARGE index=\frac{score * 10}{baseline} $$

  • score:算出的单项分数
  • baseline:记录在pgms/index.base中的基准值
  1. 总分计算公式:

$$ \Large SUM\_SCORE=e^{(\sum\limits_{i=1}^{tests\_num}log(\frac{score}{baseline}))/test\_num}*10 $$

  • test_num:一个类型中的测试项的个数,可见Run中的testCats变量
目录
相关文章
|
监控 Java 关系型数据库
『Jmeter超级干货』| Linux下Jmeter安装配置、脚本设计执行、监控及报告完整过程
『Jmeter超级干货』| Linux下Jmeter安装配置、脚本设计执行、监控及报告完整过程
1968 1
|
4月前
|
Linux Shell 开发工具
在Linux中,如何编写一个脚本来自动执行日常任务?
在Linux中,如何编写一个脚本来自动执行日常任务?
|
6月前
|
Linux
Linux每五分钟执行一次某个脚本的定时任务如何写
【6月更文挑战第28天】Linux每五分钟执行一次某个脚本的定时任务如何写
1540 0
|
监控 Shell Linux
shell脚本:你还在一条条命令查看系统性能么?快用一键监控系统脚本吧。
shell脚本:你还在一条条命令查看系统性能么?快用一键监控系统脚本吧。
147 0
启动(程序还没执行生成dump文件的代码)就崩溃的处理流程
启动(程序还没执行生成dump文件的代码)就崩溃的处理流程
|
Shell iOS开发
iOS 逆向编程(十)sh脚本(shell)编写与执行指令区别
iOS 逆向编程(十)sh脚本(shell)编写与执行指令区别
253 0
|
Shell
shell实战案例- 实现文件锁(调用外部脚本)
shell实战案例- 实现文件锁(调用外部脚本)
224 0
|
编译器 Shell 开发工具
vim的自动化配置(一条指令就够了)
vim的自动化配置(一条指令就够了)
|
Linux Shell
检测不同服务器上代码差别的shell的脚本
检测不同服务器上代码差别
1270 0