[转帖]Steam内存测试工具【转】

steam,内存,测试工具 · 浏览次数 : 0

小编点评

**Stream测试** Stream测试是内存测试中业界公认的内存带宽性能测试基准工具。 **安装步骤:** 1. 下载官方源码:`http://www.cs.virginia.edu/stream/FTP/Code/stream.c` 2. 安装编译器:`yum -y install gcc` 3. 下载版本5.9版本的`stream.c`文件 4. 使用编译器编译`stream.c`文件:`gcc -O3 -fopenmp -DN=2000000 -DNTIMES=10 stream.c -o stream` **参数解释:** * `-O3`:最高编译优化级别(3) * `-fopenmp`:启用OpenMP,适应多处理器环境 * `-DN=2000000`:测试数组大小(数组大小) * `-DNTIMES=10`:开启线程数(测试数组长度) **设置测试数组大小:** * 计算公式:`{最高级缓存X MB}×1024×1024×4.1×CPU路数/8` * 默认值:`2000000` * 实际值:根据CPU核心数和内存类型设置 **注意:** * 测试数组大小应远大于CPU最高级缓存(L3缓存)的大小。 * `Stream_ARRAY_SIZE`为`double`类型,默认值为`10000000`。

正文

 

 

转自:https://www.cnblogs.com/iouwenbo/p/14377478.html

Stream测试是内存测试中业界公认的内存带宽性能测试基准工具。

Stream安装

官方源码地址:http://www.cs.virginia.edu/stream/FTP/Code/stream.c

配好软件源,安装编译器:

yum -y install gcc

上传Stream.c(stream.c版本为5.9)到待测试机器。编译:

gcc -O3 -fopenmp -DN=2000000 -DNTIMES=10 stream.c -o stream

编译参数解释:

  • -O3:指定最高编译优化级别,即3
  • -fopenmp:启用OpenMP,适应多处理器环境,更能得到内存带宽实际最大值。开启后,程序默认运行线程为CPU线程数
  • -DN=2000000:指定测试数组a[]、b[]、c[]的大小(Array size)。该值对测试结果影响较大(5.9版本默认值2000000,。若stream.c为5.10版本,参数名变为-DSTREAM_ARRAY_SIZE,默认值10000000)。注意:必须设置测试数组大小远大于CPU 最高级缓存(一般为L3 Cache)的大小,否则就是测试CPU缓存的吞吐性能,而非内存吞吐性能。

推荐计算公式:

{最高级缓存X MB}×1024×1024×4.1×CPU路数/8,结果取整数

解释:由于stream.c源码推荐设置至少4倍最高级缓存,且STREAM_ARRAY_SIZE为double类型=8 Byte。所以公式为:最高级缓存(单位:Byte)×4.1倍×CPU路数/8

例如:测试机器是双路CPU,最高级缓存32MB,则计算值为32×1024×1024×4.1×2/8≈34393292

Stream测试原理

  • -DNTIMES=10:执行的次数,并从这些结果中选最优值。
  • stream.c:待编译的源码文件
  • stream:输出的可执行文件名

其他参数:

  • -mtune=native -march=native:针对CPU指令的优化,此处由于编译机即运行机器。故采用native的优化方法。更多编译器对CPU的优化参考
  • -mcmodel=medium ;当单个Memory Array Size 大于2GB时需要设置此参数
  • -DOFFSET=4096 ;数组的偏移,一般可以不定义

Stream使用

使用命令指定运行线程为X:
export OMP_NUM_THREADS=X

在编译输出的可执行文件(stream)所在目录下运行:
./stream
Stream测试结果示例:

Stream测试结果示例

附stream.c v5.10源码中的介绍:

附stream.c v5.10源码中的介绍

参考:

内存性能的正确解读

内存测试Stream程序分析

与[转帖]Steam内存测试工具【转】相似的内容:

[转帖]Steam内存测试工具【转】

转自:https://www.cnblogs.com/iouwenbo/p/14377478.html Stream测试是内存测试中业界公认的内存带宽性能测试基准工具。 Stream安装 官方源码地址:http://www.cs.virginia.edu/stream/FTP/Code/stream

[转帖]记录自己安装内存带宽测试工具——Stream过程

测试环境: CPU:Kunpeng 920 8Core MEM:16G Storage:200G OS:openEuler 20.03 (LTS-SP3) 1 服务器资源监控工具——Stream 1.1 编译安装——Stream 源码编译安装 ​ 下载源码: wget http://www.cs.v

[转帖]内存性能 - STREAM

https://zhuanlan.zhihu.com/p/510954835 很多时候有测试有数据, 却没有分析, 这样的性能数据是有隐患的. STREAM测试足够简单, 4个测试用例, 每个用例3行核心代码, 毫无疑问是个"简单"的测试, 但要做好缺不容易. 本文以Intel平台为例, 虽然特性可

【转帖】linux 调优篇 :硬件调优(BIOS配置)* 壹

一. 设置内存刷新频率为Auto二. 开启NUMA三. 设置Stream Write Mode四. 开启CPU预取配置五. 开启SRIOV六. 开启SMMU 通过在BIOS中设置一些高级选项,可以有效提升虚拟化平台性能。表1列出了TaiShan服务器和性能相关的BIOS推荐配置项。 表1 BIOS性

[转帖]linux 调优篇 :硬件调优(BIOS配置)* 壹

https://blog.csdn.net/tony_vip?type=blog 一. 设置内存刷新频率为Auto二. 开启NUMA三. 设置Stream Write Mode四. 开启CPU预取配置五. 开启SRIOV六. 开启SMMU 通过在BIOS中设置一些高级选项,可以有效提升虚拟化平台性能

[转帖]Redis各版本特性汇总

redis4redis5redis6redis6.2重大特性1.模块系统 2.PSYNC2 3.LFU淘汰策略 4.混合RDB-AOF持久化 5.LAZY FREE延迟释放 6.MEMORY内存分析命令 7.支持NAT/DOCKER 8.主动碎片整理 1.新增Stream数据类型 2.新增Redis

[转帖]Redis各版本特性汇总

redis4redis5redis6redis6.2重大特性1.模块系统 2.PSYNC2 3.LFU淘汰策略 4.混合RDB-AOF持久化 5.LAZY FREE延迟释放 6.MEMORY内存分析命令 7.支持NAT/DOCKER 8.主动碎片整理 1.新增Stream数据类型 2.新增Redis

[转帖]IO、NIO、BIO 傻傻分不清吗,让我对象告诉你~~

https://my.oschina.net/jiagoushi/blog/5783304 1、Stream 与 Channel stream 不会自动缓冲数据,channel 会利用系统提供的发送缓冲区、接收缓冲区(更为底层) stream 仅支持阻塞 API,channel 同时支持阻塞、非阻塞

[转帖]Nginx(3):上手Nginx,从配置文件开始

https://cloud.tencent.com/developer/article/1886147?areaSource=&traceId= 其实吧,我配置 tcp 负载均衡的时候也就弄了一下配置文件,也没了解太多的东西。 文章目录 组成部分 main 全局配置 events模块 stream

[转帖]如何使用 sed 命令删除文件中的行

https://zhuanlan.zhihu.com/p/80212245 sed 命令是 Linux 中的重要命令之一,在文件处理方面有着重要作用。可用于删除或移动与给定模式匹配的特定行。-- Magesh Maruthamuthu(作者) Sed 代表 流编辑器(Stream Editor),常