Sysbench性能测试(三): 内存性能测试
Sysbench性能测试3-3 内存性能测试sysbench内存性能测试,主要是针对不同大小的块进行连续读写或者随机读写操作。在内存性能测试中,events指的是读/写一个内存块。能获得的测量指标如下:总耗时传输速度所有events最小、最大、平均耗时平均每线程完成events数/标准差平均每线程耗时/标准差内存性能测试参数memory options:--memory-block-size=S
·
Sysbench性能测试
传送门:
Sysbench性能测试(一): sysbench简介与安装
Sysbench性能测试(二): sysbench基本使用和CPU性能测试
Sysbench性能测试(三): 内存性能测试
Sysbench性能测试(四): 文件I/O性能测试
Sysbench性能测试(五): 数据库性能测试
3-3 内存性能测试
sysbench内存性能测试,主要是针对不同大小的块进行连续读写或者随机读写操作。在内存性能测试中,events指的是读/写一个内存块。
能获得的测量指标如下:
- 总耗时
- 传输速度
- 所有events最小、最大、平均耗时
- 平均每线程完成events数/标准差
- 平均每线程耗时/标准差
内存性能测试参数
memory options:
--memory-block-size=SIZE # 内存块大小 [1K]
--memory-total-size=SIZE # 传输数据的总大小 [100G]
--memory-scope=STRING # 内存访问范围 {global,local} [global]
--memory-hugetlb[=on|off] # 从HugeTLB池中分配内存 [off]
--memory-oper=STRING # 内存操作类型 {read, write, none} [write]
--memory-access-mode=STRING # 内存访问模式 {seq,rnd} [seq]
测试实例
# 线程数=8 每1s输出一次中间结果 内存块大小=8K 传输数据总量=100G 内存访问模式=顺序访问 内存操作=写
sysbench --threads=8 --time=60 --report-interval=1 --test=memory --memory-block-size=8K --memory-total-size=100G --memory-access-mode=seq run
测试结果
Running memory speed test with the following options:
block size: 8KiB
total size: 102400MiB
operation: write
scope: global
Initializing worker threads...
Threads started!
[ 1s ] 8400.66 MiB/sec # 传输速度 MiB/s
[ 2s ] 8403.02 MiB/sec
[ 3s ] 8407.50 MiB/sec
... # 中间输出部分删除
[ 11s ] 8467.47 MiB/sec
[ 12s ] 7464.37 MiB/sec
Total operations: 13107200 (1061839.22 per second) # 总操作次数 100G=102400MB=104857600KB=13107200*8KB(块大小)
102400.00 MiB transferred (8295.62 MiB/sec)
General statistics:
total time: 12.3403s
total number of events: 13107200 # events数 即读/写一个内存块
Latency (ms):
min: 0.00 # 最小耗时 这里等于0是因为内存块太小,返回的结果数值精度不够
avg: 0.00 # 平均耗时
max: 60.02 # 最大耗时
95th percentile: 0.00 # 95%events耗时范围
sum: 62961.90 # 所有线程总耗时
Threads fairness:
events (avg/stddev): 1638400.0000/0.00 # 平均每线程完成events数/标准差
execution time (avg/stddev): 7.8702/1.15 # 平均每线程执行时间/标准差
更多推荐
已为社区贡献1条内容
所有评论(0)