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变量
目录
相关文章
|
11月前
|
监控 Java 关系型数据库
『Jmeter超级干货』| Linux下Jmeter安装配置、脚本设计执行、监控及报告完整过程
『Jmeter超级干货』| Linux下Jmeter安装配置、脚本设计执行、监控及报告完整过程
1740 1
|
3月前
|
Linux Shell 开发工具
在Linux中,如何编写一个脚本来自动执行日常任务?
在Linux中,如何编写一个脚本来自动执行日常任务?
|
5月前
|
Linux
Linux每五分钟执行一次某个脚本的定时任务如何写
【6月更文挑战第28天】Linux每五分钟执行一次某个脚本的定时任务如何写
1288 0
|
6月前
|
运维 Linux Apache
LAMP架构调优(三)——模块的安装与调用
LAMP架构调优(三)——模块的安装与调用
32 0
|
监控 关系型数据库 MySQL
『Jmeter入门万字长文』 | 从环境搭建、脚本设计、执行步骤到生成监控报告完整过程
『Jmeter入门万字长文』 | 从环境搭建、脚本设计、执行步骤到生成监控报告完整过程
503 2
|
算法 安全 Unix
【Linux基本指令(3)】几十条指令快速入手Linux/到底什么是日志?/指令的运行原理到底是什么?
13.head指令 head 与 tail 就像它的名字一样的浅显易懂,它是用来显示开头或结尾某个数量的文字区块,head 用来显示档案的开头至标准输出中而 tail 想当然尔就是看档案的结尾。
|
编译器 Shell 开发工具
vim的自动化配置(一条指令就够了)
vim的自动化配置(一条指令就够了)
|
测试技术
loadrunner 运行场景-场景运行原理
loadrunner 运行场景-场景运行原理
127 0