|
本文目录连接天河二号天河二号运行环境天河二号运行程序天河二号超级计算机于2013年在国家超算广州中心已正式投入运行,委托中山大学管理,目前是中国超算能力排名第二、全球排名前十的超级计算机。天河二号价格大约是0.1元/小时/cpu,费用不算高。/ I, Q/ }- u6 ^) i+ [# s8 a; h
本文简要介绍天河二号的使用步骤,包括连接到超级计算机、运行并行程序等。内容主要参考天河二号官方下方的文档,如遇到请问,请查看官方文档或联系工作人员。( o+ X' J& z+ R" C0 r& j! P( Q6 y
准备工作:联系天河二号工作人员,填写申请表,审核通过后获得账号、密码、登录密钥和使用说明手册。
+ v' w( f6 v% i9 ? 连接天河二号返回目录连接天河二号机器前,需先登录VPN。如果未安装VPN,先进入网页https://vpn3.nscc-gz.cn:4433下载Windows客户端,然后安装并运行程序。在出现的登录界面中填入以下信息:& r( k% F2 ]) N5 C
服务器:vpn1.nscc-gz.cn
' T2 C* U1 ~; O% b端口: 44339 m1 A) G/ j& _# ]6 J0 P
账号: 账号
( s& H+ ?* o) h7 M. W密码: 密码7 k0 x4 r4 U3 `0 C
如果信息无误,点解登录后VPN客户端会最小化到右下角托盘并显示绿色图标。
: P7 ~2 e5 R* m, D5 Z3 I登录VPN后,才可以用SSH方式连接到天河二号的登录节点。登录节点默认的认证方式是免密私钥认证,需提供开设账号时分发的私钥作为凭证。使用OpenSSH客户端连接的示例为:
5 R, i' |4 M1 U. j3 R7 E6 mchmod 600 private_key && ssh -i private_key username@172.16.22.119 g' v5 ]" y4 I! a) s/ J j
private_key在windows下默认为755权限,OpenSSH会拒绝使用安全性低的私钥,chmod保证读写权限均为私有。
. g2 l+ _0 F0 K4 o 天河二号运行环境返回目录通过一些命令可以探测到天河登录系统的运行环境。9 [8 `) z+ p9 q [
uname -a: 系统的内核版本是2.6.32cat /proc/cpuinfo: 登录节点使用了intel芯片,含4个物理CPU,每个CPU8核心16线程free -g: 登录节点配备了128G内存df -h: 大约5P的硬盘存储gcc -v: gcc版本为4.4.7icc -v: 系统默认的icc版本为14.0.2,其他版本需使用module命令加载mpicc -v: mpi版本为3.1.3,使用icc 14.0.2编译make -v: make版本为3.81cat /etc/hosts|grep ln: 系统有几十个登录节点,这也解释为了登录的时候会经常提示指纹不匹配module avail: 系统支持模块,高版本的GCC/CUDA/FFT等均可以模块方式加载,无需自行编译ping cn.bing.com/ping 114.114.114.114: 提示找不到主机,表明机器无法访问外网通过查看yhinfo等命令的帮助,可以看到任务管理系统使用的是slurm。把slurm命令中的s替换成yh,则是yh系列的各个命令。3 T& U& G3 v% ]# k
计算节点无法登录,可以通过yhrun执行程序探测。以下是一些计算节点的信息:: ^: |- S) E$ j
CPU: Xeon(R) CPU E5-2692 v2 @ 2.20GHz(未启用超线程) 内存: 64G 操作系统:天河自编译的Linux系统,内核版本2.6.323 @0 _3 u8 f5 y7 K @. o0 a! w6 p7 H
天河二号运行程序返回目录按照官方指南,程序的源码和编译可在主目录下,运行时的存储应放置在BIGDATA目录中。程序运行的命令主要是yhrun和yhbatch,yhrun是交互式提交作业,yhbatch是批量提交作业。实际使用中建议用yhbatch提交作业。
2 M" A: s$ f/ ]) ?# Nyhinfo/yhi通过yhinfo或者yhi可查看用户可用的节点状态。命令的输出中,需要关注的是PARTITION和STATE两列。PARTITION指示任务可提交到的分区,在yhrun中会使用;STATE表示节点状态,只有idle的节点才是可直接使用的。
# O% V& K) Z4 [, B% a) `, r要查看所有分区/队列信息,可加上-a选项。
$ `$ V3 y& G, t+ H9 Xyhrunyhrun用来交互式提交作业。基本用法是: yhrun [options] program [program-options]。options中,常见指定如下选项:
; s) l3 |# K& ~. t6 U3 w) e& ^-n: 任务数。在MPI作业中,即进程数-p: 任务运行分区。可用分区通过yhi命令查看-N: 节点数。希望作业运行在几个节点上-c: 任务使用的核心数。该值默认为1,非openMP程序一般用不到,指定了也不影响运行。天河二号的每个计算节点配置24核,并且是独占式的。这意味着节点在同一时间只能被一个用户所使用,为了节省结算计时,尽量让N=[n/24],或者不指定-N参数。. A! d/ Y( T) p+ U( W! t0 W7 k0 A
yhrun可以替代mpirun使用,而不是简单的在各个主机上执行相同程序。例如在多个进程上运行非MPI程序:yhrun -n20 -p free hostname,结果将返回进程所在节点的主机名,结果类似于pssh执行同一条命令。通过yhrun运行的程序能否让MPI程序的各个进程正常进行通信和交互,刚开始尚有疑惑。% C- Y0 h0 @2 Y+ S
为了检测yhrun和mpirun有相同效果,写了一个小demo进行校验。以下的测试代码:; d, D" s6 L+ Z2 o! L+ R
#include "mpi.h"* K" \7 |4 j1 [0 d8 @9 u
#include
7 j/ I+ T- ?9 }+ I7 hint main(int argc, char **argv)" V( c7 } _& r( Q
{
3 Y3 e v( k9 q/ P% L7 r, {: R7 j int rank, size, namelen;0 y* L, ?% z2 L& M4 W
char name[1024];% q" Z- _- \+ ~' C; |8 W8 J4 T8 ~7 K
MPI_Init(&argc, &argv);, R H: l, s* F2 J* `. F5 h3 W
MPI_Comm_rank(MPI_COMM_WORLD, &rank);1 L8 a+ i0 U5 L3 i/ g: o
MPI_Comm_size(MPI_COMM_WORLD, &size);
# \1 b6 {2 A# E6 X. A0 W MPI_Get_processor_name(name, &namelen);
# {& U k# @1 u6 }+ d printf("Hello world! I'm %s(%d) of %d\n", name, rank, size);
7 c+ l8 j/ k% _2 | MPI_Finalize();
% V( p7 q! U2 M% j- ^8 g/ b) I return 0;
( p4 J6 ^( X6 V$ u- A}
4 U. q" b* r& B, X6 q8 h. ]" q编译和运行:
6 n( p7 @0 n5 s6 @mpicc -o foo -O2 demo.cpp
. L, b/ o/ {- @yhrun -n20 -p free ./foo) L3 ]" n7 P9 C; U' z
从结果上看,yhrun的执行效果和mpirun一致,说明yhrun确实可以替代mpirun执行有通信的多进程程序。
7 {" D9 \4 l6 P8 M# Cyhbatchmpirun是交互式的提交作业,这意味着会一直占据终端,直到程序开始计算并将结果返回回会释放终端。大部分的程序运行时间周期都较长,在等待期间,如果用yhrun,用户只能等待结果或另开连接,否则无法进行其他操作。实际使用中,应使用yhbatch提交作业,yhrun执行具体任务。作业系统在yhbatch提交时申请的资源满足后,调度执行任务并将结果存放到用户的目录下。
4 Q: M( I# U' M6 f- ryhbatch命令选项和mpirun命令相差不大,猜测的主要不同是yhbatch是向调度中心进行资源申请,只有满足这些条件才运行用户的程序,否则继续等待。# p9 b, v; r* Y8 r: s9 H& X
使用yhbatch首先建立一个脚本文件,里面放入程序执行命令:3 H+ G4 N' k/ u: g$ _$ m( J( b9 J
#!/bin/bash
7 ] t5 k+ _9 b* l! s* T5 Qyhrun -n10 -p free ~/foo3 [! p7 a7 E+ q2 q4 @/ e
然后使用yhbatch提交:chmod u+x ./batch.sh; yhbatch -n10 -pfree ./batch.sh。yhbatch中的-N等参数应该不小于yhrun中的参数,否则运行时的进程数和节点可能并非所想,甚至出现资源错误提示。( ?( m! r1 P1 S) S( M0 G
yhqueue/yhqyhbatch提交作业后,使用yhqueue/yhq可查看正在运行的任务状况。
4 `( Z5 o) H' f2 w# Vyhcancal提交到任务队列后,yhq可查看提交或者正在运行的任务id。如果想终止任务,使用yhcancel。
$ J; H' @3 V Q9 I7 L其他事项,请参考官方说明手册。
; f* i$ v- l7 x; [& I2 CAD:【国外VPS推荐】 Vultr全球16个数据中心,高速SSD硬盘,月付2.5$起,注册充10$送100$打赏赞(9) |
|