Wiener is named in honor of Norbert Wiener, a mathematician who devised an algorithm to remove noise from a signal or image. The technique became known as “Deconvolution”. The alternative name for this supercomputer is the “UQ Deconvolution Facility”.
Wiener phase 1.0 (gpunode-0-[0-16]):
2 * NVIDIA Volta V100 with
Wiener phase 2.0 (gpunode-1-[0-14]):
4 * NVIDIA Volta V100 SXM2 with
All compute nodes have 28 CPU cores and 56 threads (slurm cpus), 384GB of ram (the max quota in jobs per user is 300GB).
Wiener is exclusively for accelerator-class (GPU) codes. CPU-only workloads are not permitted on Wiener. CPU-only workloads found running on Wiener will be killed. Users are required to use their UQ staff ID to apply for access to Wiener. Student accounts are not permitted on Wiener.
Set 1 of the Training resources explains how to use Putty to connect to a HPC with the basics found here. To connect to Wiener please use:
Hostname: wiener.hpc.dc.uq.edu.au
Port: 22
For those using command line ssh:
ssh wiener.hpc.dc.uq.edu.au
Wiener enforces MFA (multi factor authentication).
For UQ users, this will use their DUO MFA that is used for all other access to UQ resources.
Users will first be asked for their password (or key). After users have entered this, they will see one or more options given. Choose the option you wish to use and type the respective number on the command line. If you have only one option set up, you still need to type “1” and press “enter”.
After this you will be logged into Wiener.
You have access to a set of locations to store data
When you login you will see a summary of your home and scratch allocations.
------------------------------------------------------------------------------------------------------------------------------------------
Block Limits |File Limits
Filesystem Fileset type blocks quota limit in_doubt grace | files quota limit in_doubt grace Remarks
SCRATCH2 root USR 419.4M 2T 2.148T 0 none | 1871 0 0 0 none
CLUSTERDATA2 root USR 1.588G 5G 10G 0 none | 12190 0 0 0 none
------------------------------------------------------------------------------------------------------------------------------------------
You can also use this command. ` /usr/lpp/mmfs/bin/mmlsquota -e –block-size=auto SCRATCH2 CLUSTERDATA2`
We recommend to use command line scp
and sftp
. They are accessible to all users, via a shell for Linux and Mac users and via WSL and cmd
for Windows users.
scp file username@wiener.hpc.dc.uq.edu.au:/path-to-place-for-file/
For example
scp test.dat username@wiener.hpc.dc.uq.edu.au:/scratch/user-OU/username/
will copy the file test.dat
to the user’s scratch directory.
sftp username@wiener.hpc.dc.uq.edu.au
You will see sftp>
as prompt once you have logged in.
ls
and cd
work as usual on the Wiener end. Use lls
to list files on your desktop/laptop and lcd
to change directories on your desktop/laptop.
Use get
to pull files and directories from Wiener to your desktop/laptop and use put
to move files and directories from your desktop/laptop to Wiener.
Windows users can also use WinSCP if they require a graphical SFTP client. WinSCP allows the MFA authentication without extra setup. WinSCP also allows multiple files and directories transfer without having to re-enter the MFA passcode.
Wiener has one login node, wiener.hpc.dc.uq.edu.au. You do not need to be on the UQ VPN to access it.
We ask that users be mindful of the nature of a login node. This single login node is shared by all users accessing and using Wiener. Do not run computational workloads on the login nodes, please. Compiling, yes. Assembly of your code, yes. Editing your scripts and moving things around, yes. Submitting your jobs via “sbatch”, yes. Running “jobs” on the login node and not using the SLURM scheduler…no.
The training resources have a short video on how to use software modules to load installed software on HPC.
The basic commands are:
module overview
- shows a brief list of all available modules, and the number of distinct versions
module avail
- shows all available main modules
module -t avail
- shows a terse single column list of the available modules
module avail [SOFTWARE-NAME or KEYWORD]
- shows all modules for SOFTWARE-NAME or KEYWORD
module spider [SOFTWARE-NAME or KEYWORD]
- shows all possible modules for SOFTWARE-NAME or KEYWORD
module load [SOFTWARE-NAME/VERSION]
- loads a specific software version
module unload [SOFTWARE-NAME/VERSION]
- unloads a specific software version
module list
- lists all currently loaded software modules
module purge
- unloads ALL currently loaded software modules
IMPORTANT: Modules on Wiener are NOT self-contained. You will usually need to load all its dependencies as well. Please use
module show software-name/version
and then look for the Required modules or Modules required in the lines starting with whatis.
Please note:
Use the full module name, software/version, to be sure to load the version you need and ensure that your research is consistent and repeatable. In case of a dependencies for modules, the exact version is required as otherwise the software is unlikely to work.
salloc --nodes=1 --ntasks-per-node=1 --cpus-per-task=1 --mem=50G --job-name=TEST --time=05:00:00 --partition=gpu --gres=gpu:1 srun --pty /bin/bash -l
This will log you onto a compute node. To run a job just type as you would usually do on the command line. As srun
was already used in the above command there is no need to use srun
to run your executables, it will just mess things up.
You will need to add a type
to the –gres part if you are targeting a particular GPU, –gres=gpu:[type]:1. Please see below for the options.
Once you are done type exit
on the command line which will stop any processes still running and will release the allocation for the job.
You would usually write a slurm script to subimit your jobs. Once you have a script you use sbatch
to submit this script. For example if you have a script called first-job-script
then you use
sbatch first-job-script
to submit the slurm script and your job.
The different request flags mean the following:
#SBATCH --nodes=[number]
- how many nodes the job will use
#SBATCH --ntasks-per-node=[number]
- This is 1 for single thread jobs and multi thread jobs. This is 28 (or less if single node) for MPI jobs.
#SBATCH --cpus-per-task=[number]
- This is 1 for single thread jobs, number of threads for multi thread jobs. --cpus-per-task
can be undertstood as OMP_NUM_THREADS
.
#SBATCH --mem=[number M|G|T]
- RAM per job given in megabytes (M), gigabytes (G), or terabytes (T).
#SBATCH --mem-per-cpu=[number M|G|T]
- alternative to the request above, only relevant to MPI jobs.
#SBATCH --gres=gpu:[type]:[number-of-gpus]
- to request the use of 1 or more GPUs. [type]
can be tesla
with up to 2 GPUs per node or tesla-smx2
with up to 4 GPUs per node.
#SBATCH --time=[hours:minutes:seconds]
- time the job needs to complete.
#SBATCH -o filename
- filename where the standard output should go to
#SBATCH -e filename
- filename where the standard error should go to
#SBATCH -job-name=[Name]
- Name for the job that is seen in the queue
#SBATCH --partition=gpu
#SBATCH --array=[range]
- Indicates that this is and array job with range number of tasks.
srun
- runs the executable and will receive info on number of threads, memory, etc from Slurm. There is no need to specify them here.
See man sbatch
and man srun
for more options (use arrow keys to scroll up and down and q
to quit)
The following provide example scripts that can be adapted to needs and different software used.
#!/bin/bash
#SBATCH --job-name=my-gpu-job
#SBATCH --nodes=1
#SBATCH --gres=gpu:tesla:1
#SBATCH --ntasks-per-node=1
#SBATCH --cpus-per-task=7
#SBATCH --mem-per-cpu=5G
#SBATCH --partition=gpu
#SBATCH --time=00:10:00
The --gres
(global resource) parameter is used to specify how many GPUs are required per node. This option is essential as otherwise Slurm will not allocate a GPU to the job. Wiener has nodes that can provide two or four GPUs. It takes the form:
gpu:[type]:[number-of-gpus].
Wiener has two types of GPU available:
Name | GPU Memory | Gres Type |
---|---|---|
Tesla V100-PCIE | 16GB | tesla |
Tesla V100-SXM2 | 32GB | tesla-smx2 |
Note: the gres type is smx2
and it does not match the actual GPU name SXM2
Wiener has 17 nodes that have two V100-PCIE GPUs and 15 nodes that have four V100-SXM2 GPUs.
If you simply want to schedule a job and do not care what type of GPU is allocated to your job, your gres string would be --gres=gpu:1
. This would run your job on the first available node.
If you require a GPU that has 32GB of memory you would specify --gres=gpu:tesla-smx2:1
.
If you want to run your job on multiple GPUs only the SXM2 nodes can provide three or four GPUs on the same node e.g., --gres=gpu:tesla-smx2:4
.
The following command run the python code once the job is allocated. In this example we will use the anaconda environment manager.
Load the CUDA module which provides the GPU libraries required by python
module load cuda/11.7.0
Load the anaconda module
module load anaconda/3.7
Initialise anaconda (this is broken for anaconda/3.5)
eval "$(conda shell.bash hook)"
Activate your environment.
conda activate myenv
Run your code
srun python my-python-code.py
For detailed instructions on how to work with anaconda and conda environments please see the conda guide
A complete slrum script example looks like this (this will need to be adapted to currects paths and programs before using it.)
#!/bin/bash
#SBATCH --job-name=my-gpu-job
#SBATCH --nodes=1
#SBATCH --gres=gpu:tesla:1
#SBATCH --ntasks-per-node=1
#SBATCH --cpus-per-task=7
#SBATCH --mem-per-cpu=5G
#SBATCH --partition=gpu
#SBATCH --time=00:10:00
module load cuda/11.7.0
module load anaconda/3.7
eval "$(conda shell.bash hook)"
conda activate myenv
srun python my-python-code.py
squeue -u YourUsername
– will only print your jobs
squeue -u $USER
squeue --me
Here are some other useful additions to the squeue command. For information on what all these means please consult the man pages.
squeue -o "%12i %7q %.9P %.20j %.10u %.2t %.11M %.4D %.4C %.14b %8m %16R %18p %10B %.10L"
JOBID QOS PARTITION NAME USER STATE TIME NODE CPUS TRES_PER_NODE MIN_MEMORY NODELIST(REASON) PRIORITY EXEC_HOST TIME_LEFT
sinfo is used to obtain information about the actual nodes. Here some useful examples.
sinfo
PARTITION AVAIL TIMELIMIT NODES STATE NODELIST
sinfo -O Partition,NodeList,Nodes,Gres,CPUs
PARTITION NODELIST NODES GRES CPUS
sinfo -o "%.P %.5a %.10l %.6D %.6t %N %.C %.E %.g %.G %.m"
PARTITION AVAIL TIMELIMIT NODES STATE NODELIST CPUS(A/I/O/T) REASON GROUPS GRES MEMORY