Linpack测试方法

一.编译器

  安装gcc。

二.并行环境MPI的建立(MPI的使用需要用到Python)

1.创建SSH信任连接(在root目录下)

(1)更改/etc/hosts文件

  #vi /etc/hosts   打开hosts文件,更改如下:

  127.0.0.1 localhost.localdomain localhost

  node01的IP scc-m

  node01的IP node01

  node02的IP node02

  node03的IP node03

  node04的IP node04

  具体实施:

  127.0.0.1       localhost.localdomain   localhost

  202.117.49.128  scc-m

  202.117.49.128  abc             abc

  202.117.49.129  xyz             xyz

(2)在node01生成SSH秘钥对

  #ssh-keygen -t rsa      //一路回车即可产生.ssh文件

  #ls -a   查看是否有.ssh文件夹

(3)进入.ssh目录

  #cd .ssh

(4)生成authorized_keys文件

  #cp id_rsa.pub authorized_keys

(5)退出到root目录

  #cd ..

(6)建立本身的信任连接

  #ssh node01     按提示输入yes(三个字母要打全)

(7)设置node02(node02的root目录下)

  #ssh-keygen -t rsa     生成.ssh文件夹       //注意不要多键入空格

  #scp node01的IP:/root/.ssh/* /root/.ssh    拷贝node01上的.ssh文件夹覆盖本地的

  #scp node01的IP:/etc/hosts /etc/hosts      拷贝node01上的hosts文件覆盖本地的

  #ssh node01  提示处输入yes回车

  设置node03,node04的方法与node02相同

  具体实施:

  #scp 202.117.49.128:/root/.ssh/* /root/.ssh //注意不要多键入空格

  #scp 202.117.49.128:/etc/hosts /etc/hosts

(8)确认四台机器的信任连接已建立

   对每个节点执行:

  #ssh node01

  #ssh node02

  #ssh node03

  #ssh node04

  在提示处输入yes回车,最后确定无需输入密码并且没有任何提示信息即可登陆("Last login:时间日期"提示信息除外)

2.安装MPICH2(在每个节点root目录下,而且所以节点上的目录一模一样)

(1)解压缩

  #tar -zxvf mpich2-1.0.7.tar.gz

  或者 #gunzip -c mpich2-1.0.7.tar.gz|tar xf mpich2-1.0.7.tar

(2)创建安装目录

  #mkdir /usr/MPICH-instsll

(3)进入mpich2解压目录

  #cd mpich2-1.0.7

(4)设置安装目录

  #./configure --prefix=/usr/MPICH-install

(5)编译

  #make

(6)安装

  #make install

(7)退出到root目录

  #cd ..

(8)通过编辑.bashrc文件修改环境变量

  #vi .bashrc

修改后的.bashrc文件如下:

   # .bashrc

   # User specific aliases and functions

alias rm='rm -i'

alias cp='cp -i'

alias mv='mv -i'

   PATH="$PATH:/usr/MPICH-install/bin"   新增加的

   #Source global definitions

if [ -f /etc/bashrc ]; then

. /etc/bashrc

fi

(9)测试环境变量设置

  #which mpd

  #which mpicc

#which mpiexec

#which mpirun

(10)修改/etc/mpd.conf文件,内容为secretword=myword

  #vi /etc/mpd.conf

   设置文件读取权限和修改时间

  #touch /etc/mpd.conf

  #chmod 600 /etc/mpd.conf

(11)创建主机名称集合文件/root/mpd.hosts

  #vi mpd.hosts

  文件内容如下:

node01

node02

node03

node04

3.测试

(1)本地测试

  #mpd &    启动

  #mpdtrace 观看启动机器

  #mpdallexit 退出

(2)通过mpd.hosts运行集群系统

  #mpdboot -n number -f mpd.hosts        number为要起动的机器个数

  #mpdtrace

  #mpdallexit

(3)测试运行MPICH的例子程序

  #mpdboot -n 4 -f mpd.hosts   启动4台机器

  #mpiexec -n number /usr/MPICH-install/examples/cpi     number为使用的进程数

  #mpdallexit

(4)如果测试不能通过,请进行第四步

4.问题解决

(1)通过mpdcheck获得一写帮助信息

  #mpdcheck –pc

(2)查错

  #mpdcheck -l

(3)通过mpd.hosts文件查错

  #mpdcheck -f mpd.hosts  如果无错误

  #mpdcheck -f mpd.hosts  -ssh

(4)如果上述无错误,可略过此步

  对任意两台机器进行查错

  m1: #mpdcheck -s  输出主机名host和端口port

  m2: #mpdcheck -c host port

  注意:以上四步都是在没有运行mpd的情况下进行的

(5)mpd查错

  m1: #mpd -e & 返回使用的端口

  m2: #mpd -h m1 -p echoed_port_m1 &

  

三.BLAS的安装

1.下载blas.tar和cblas.tar 。需要先安装blas,后安装cblas。

2. blas.tar解压缩后直接make,生成blas_LINUX.a静态库。

3. cblas.tar解压缩后,选择MakeFile.LINUX作为配置文件,另存为或者链接为MakeFile.inc。修改MakeFile.inc中的配置:

BLLIB 和 CBDIR 的路径。

第一个是 blas_LINUX.a 所在的路径。

BLLIB = /*/blas_LINUX.a

第二个是 CBLAS 解压的存放路径。

CBDIR = /*/CBLAS

最后执行make all,在/*/CBLAS/lib/LINUX里面生成cblas_LINUX.a

4. 我们所关注的就是这两个.a库文件的链接路径。

四.HPL的安装、编译与运行

1.从http://www.netlib.org/benchmark/hpl/software.html下载"hpl.tgz";

2.tar -xzvf hpl.tar    //创建一个"hpl"目录

3.进入/hpl/setup目录,选择一个合适的make文件“Make.Linux_PII_CBLAS”,并将其拷贝到/hpl目录下

4.修改该文件

  ARCH    = Linux_PII_CBLAS       //必须与文件名Make.<arch>中的<arch>一致

  TOPdir  = /usr/local/hpl            //指明hpl程序的源文件目录

  MPdir   = /usr/MPICH-install        //指明MPI的安装目录

  LAdir   = /*/BLAS   //BLAS或VSIPL库所在目录

  LAlib   = /*/CBLAS/lib/LINUX/cblas_LINUX.a  /*/BLAS/blas_LINUX.a (注意这两个库链接的先后顺序)

  CC      = /usr/local/mpich2/bin/mpicc

  CCFLAGS = $(HPL_DEFS) -fomit-frame-pointer -O3 -funroll-loops –lpthread //CC的配置

  LINKER  = /usr/local/mpich2/bin/mpif77

5.编译

  make arch=Linux_PII_CBLAS

6.运行

(1)修改配置文件/usr/local/hpl/bin/Linux_PII_CBLAS/HPL.dat

  仅修改了第4行,使之将结果输出至HPL.out

(2)运行

好像必须在/usr/local/hpl/bin/Linux_PII_CBLAS下执行

  mpirun –np 4 /usr/local/hpl/bin/Linux_PII_CBLAS/xhpl   //使用相对路径时居然不行?

(3)查看结果

  vi HPL.out

************************************************************************

以下是附加的步骤三、四,更新了GotoBlas数学库和hpl2.0来进行LinPack测试

************************************************************************

附加三. GotoBlas的安装

1. 下载gotoBlas.tar.gz。我这里采用的是GotoBLAS-1.26.tar.gz

2. 解压缩,进入目录,根据你的机器是32位还是64位来执行

./quickbuild.32bit

3. 编辑Makefile.rule(我基本没有更改);更改getarch.c里面的archtecture,使之符合自己的机器

4. 执行 make

5. cd exports 执行make so (我的这一步没用通过,不过貌似不影响后面使用)

6. 生成一堆 .o .so .a文件,后面HPL用到的是libgoto.a和libgoto_penrynp-r1.26.a

附加四:hpl2.0的安装

1. 下载源码,解压缩

2. 进入目录,由于建立一个“Make.Linux_PII_GOTO”的文件,源码中没有这个类型现成的make文件,复制“Make.Linux_PII_CBLAS”中的内容到其中。

3. 主要修改以下几项:

ARCH    = Linux_PII_GOTO        //必须与文件名Make.<arch>中的<arch>一致

LAdir   = /*/GOTOBLAS   //GOTOBLAS库所在目录

LAlib   = /*/ GOTOBLAS /libgoto_penrynp-r1.26.a  /*/ GOTOBLAS /libgoto.a (注意这两个库链接的先后顺序)

4. 编译

make arch=Linux_PII_GOTO

5. 运行

Linpack测试环境的搭建相关推荐

  1. dg建立linux分区,Linux平台 Oracle 11g DG测试环境快速搭建参考

    Linux平台 Oracle 11g DG测试环境快速搭建参考 环境现状: 两台虚拟主机A和B: 1. A机器已安装ASM存储的Oracle 11g 实例 参考: 2. B机器已安装系统,配置以及目录 ...

  2. wap2.0有关windows mobile模拟器测试环境的搭建

    wap2.0有关windows mobile模拟器测试环境的搭建 2009年08月01日 星期六 19:38 理论上测试只需要支持wap2.0的模拟器即可,但是各款模拟器不尽相同,起初我用openwa ...

  3. oracle dg 搭建方式,Linux平台 Oracle 11g DG测试环境快速搭建参考

    环境现状: 两台虚拟主机A和B: 1. A机器已安装ASM存储的Oracle 11g 实例 2. B机器已安装系统,配置以及目录结构均和A机器保持一致 /u01 + 3块ASM盘 DG部署规划: pr ...

  4. c语言什么是测试环境,vscode搭建与测试c语言运行环境

    1.在vscode里面下载c/c++官方插件: 先右键标红那里,选择make for installation  然后左上角菜单installation下拉选择apply changes:安装完成就可 ...

  5. 软件测试培训:如何搭建测试环境

    如何搭建测试环境?这是很多测试人员都需要了解的,测试是每个产品上线前必备的一个检验,不管是什么产品,做好有效的测试是对产品质量的一个负责,软件测试环境要考虑的就是软件在什么软硬件下能正常运行,什么环境 ...

  6. web应用如何确定能同时允许多少用户连接?_Web测试环境搭建+测试要点汇总

    一.Web测试环境搭建 软硬件包括:电脑一台.JDK1.6.Tomcat7.0.mysql.IE浏览器.Firefox浏览器.Chrome浏览器.SVN客户端 通过SVN客户端导出最新的Web工程部署 ...

  7. Celery简介及Docker测试环境搭建

    Celery 简介 任务队列一般用于线程或计算机之间分配工作的一种机制. 任务队列的输入是一个称为任务的工作单元,有专门的工作进行不断的监视任务队列,进行执行新的任务工作. Celery 通过消息机制 ...

  8. 入门级----测试的执行、环境的搭建、每日构建、测试记录和跟踪、回归测试、测试总结和报告...

    测试用例的准备,都是为了执行测试准备的. 测试环境的搭建 (1)测试数据:有些测试需要使用大批量的数据,例如容量测试.压力测试等.根据产品的具体测试要求,可能需要在数据库表插入大量的数据,准备大量的文 ...

  9. 如何搭建基于C#和 Appium 的 Android自动测试环境

    转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具.解决方案和服务,赋能开发者. 如果想做手机端的自动化测试,Appium是首选的测试框架,因为网上使用的人多,资料丰富,支持语言多 Jave ...

最新文章

  1. oracle导入到mysql命令_oracle数据库导入导出命令
  2. docker 疑难杂症
  3. 自定义控件:广告内容后期加载。以及NamingContainer层次的应用
  4. VTK:Picking之HighlightPickedAct
  5. java 后端校验_如何实现Java后端数据校验?看这篇就足够!
  6. Chrome浏览器和百度搜索引擎兼容度不佳
  7. 谈对阿里应用分层的思考
  8. 全球国家和地区代码列表
  9. arm的一些概念(ARM9、Cortex的区别)
  10. Graph Convolutional Matrix Completion,GC-MC
  11. 使用互传APP实现Android手机投屏到windows电脑
  12. 【4022】有些KPI的完成,╮(╯▽╰)╭
  13. VOC数据集的划分(训练集,验证集,测试集) 生成txt文件和标签
  14. VMware workstation虚拟机REHL8下配置安装Django 4.0.6 +uwsgi 2.0.20 +nginx1.22+Mariadb10.9.1
  15. 如何用计算机解开op手机密码,oppo清除锁屏密码【操作技巧】
  16. 飞链云数字艺术品-如何生成邀请海报
  17. proteus中仿真51单片系列之---blink点灯程序
  18. 百度离线瓦片地图原理解析(附C#源码,可下载带样式地图)
  19. CMU 15-445 数据库课程第五课文字版 - 缓冲池
  20. 测试人员如何避免背黑锅

热门文章

  1. iphone长截图哪个软件好_Windows长截图技巧、iPhone免费长截图软件
  2. 游戏模型:不是天生,不用PS,3DMax教你怎么拥有长长的睫毛
  3. 单元测试 0%-40%+经验
  4. python视频教程全集-Python视频教程全集带你入门
  5. 基于verilog实现的VGA
  6. xray扫描器的使用 (长亭科技公司创造)
  7. 异常 exception
  8. Linux—vi命令详解
  9. Python的lasso回归分析
  10. nyoj-264-国王的魔镜