Skip to content

sinzlab/hlrn-access

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

34 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

A Guide for Accessing the GPUs Cluster at the NHR/HLRN HPC.

This is a guide for accessing the computational resources at NHR/HLRN. It is a condensed version of this guide, which should be referred for further information.

Hardware and Nodes

The NHR/HLRN HPC consists in a cluster of processing nodes, to which users can submit SLURM jobs from access nodes within the same HPC system. For a complete list of resources, please refer to this link.

Creating an account

Warning: The websites and documentations related to NHR are being updated constantly. So, if the instructions presented here doesn't work, please refer to this link.

If you already have a full GWDG account, just ask Fabian to give you access to one of his projects using the Project Portal. It is important to login to the AcademicCloud at least once to be able to use the HPC Project Portal or be added to projects.

If you don't have a GWDG account, there are two options: (1) send an email to [email protected] asking for a test account (for more info, please refer to this link). (2) Send an email to [email protected] with Fabian in CC mentioning the institute you will be working at and a short description/working title of your thesis/project as well as the duration of the project (for more information, please refer to this link). Option (2) is preferred for users who already have a student (e.g. students of the University of Göttingen) or guest account on AcademicCloud.

Accessing the servers

The password that you set is for the portal only. In order to access the nodes on the HLRN cluster, you need to have an SSH key uploaded to the AcademicCloud portal: https://docs.hpc.gwdg.de/start_here/connecting/upload_ssh_key/index.html#upload-key.

With the SSH key uploaded, you can now log into the cluster using ssh: ssh -i <path_to_your_private_key> -l <your_username> glogin9.hlrn.de. We recommend using glogin9 instead of others because it allows you to access the /scratch-grete/ directly from the assigned GPU compute node. A project-specific login node can also be found on the details page of an assigned project on the project portal

Testing the servers

Once in the server, to test its functionality you can follow the the tutorial available in https://gitlab-ce.gwdg.de/dmuelle3/deep-learning-with-gpu-cores.

Using the servers

There are essentially two ways to use the HLRN cluster

  1. build an apptainer (formerly singularity) image, run it, ssh into the container on a compute node
  2. set up a conda/mamba environment on your scratch, ssh into the compute node, activate your conda/mamba environment

Attention: Make sure to run heavy scripts always on compute nodes and not login nodes (entry points after connection via ssh, normally named like glogin10). More information about the cluster organization can be found here.

1. Using the nodes with apptainer

At the moment these instructions work with Linux and Mac. It is not tested on Windows.

In order to run code with your dependencies on a compute node you need three things in order:

(1) create an apptainer container (docker is not allowed),

(2) run the apptainer container on the node, and

(3) install and setup vscode and connect to the running apptainer container in order to develop on the assigned node.

Creating the apptainer container

Create an apptainer image using the apptainer definition file (find examples under apptainer/). You can also convert a docker image into an apptainer image: https://docs.sylabs.io/guides/3.0/user-guide/build_a_container.html. In order to build an apptainer image, use: apptainer build --fakeroot <apptainer_example.sif> <apptainer_example.def>. (Remember to load apptainer first by doing module load apptainer)

Note that the image needs to be built on a Linux machine.

Setup vscode on your local machine

Three steps:

(1) Install vscode https://code.visualstudio.com on your local machine;

(2) Install the extension Remote - SSH: https://marketplace.visualstudio.com/items?itemName=ms-vscode-remote.remote-ssh;

(3) ssh into the login node glogin9 via vscode. In order to do this, add a config file (a template config is provided in the repo) under ~/.ssh/config and ssh into the login node via the Command palette on vscode (keyboard shortcut cmd + ^ + p on mac) by using the option "Remote-SSH: Connect to Host...". Please add both the entries as in the config file provided, i.e., "Host hlrn ..." as well as "Host hlrn-*".

Doing this creates a .vscode-server folder on the login node that you will need to use the vscode frontend on your local machine and to develop on the assigned GPU compute note on the cluster.

Running the apptainer container on SLURM

Once the apptainer image is built, upload the image (.sif file) to the login node (e.g. to your home dir). In order to run the apptainer image (i.e., create a container/instance):

(1) create an example.sbatch file (see example.sbatch in this repo),

(2) use the sbatch command on the login node to run the example.sbatch file, for example: sbatch example.sbatch. We recommend you familiarize yourself with slurm an slurm commands, which will help you see (a) what nodes are available, (b) how to check your running jobs, (c) how to read the output and logs, (d) how to change the sbatch file in order to customize your requirements (such as needing more GPU nodes), etc. Please see the slurm documentation page for more: https://slurm.schedmd.com.

Remote-ssh'ing into the assigned compute node

(1) Once you run the sbatch command, your built apptainer image will run as an instance on your assigned GPU compute node. You can find out which one via the command: squeue --me. Copy the name of your assigned compute node <compute-node-name> listed under "NODELIST" (e.g. ggpu111).

(2) You can now directly remote ssh into the instance running on the GPU node via vscode locally. In order to do this, open the Command palette on vscode (keyboard shortcut cmd + ^ + p on mac) by using the option "Remote-SSH: Connect to Host..." and type in hlrn-<compute-node-name> and hit enter. This should open a new vscode window on the compute node within your apptainer instance.

2. Using the nodes with a conda environment

Install mamba and set up your environment

Follow the guide provided by Anwai Archit here and install mamba in /scratch/usr/$USER/mambaforge. After this, set up your environment with all the libraries that you require. This can be done on the login node of the HLRN. However, be aware that you have to install mamba and set up your environment at the right /scratch directory (i.e. use login node glogin9 for gpu nodes, glogin1-glogin8 for cpu nodes).

Setup vscode on your local machine

Three steps:

(1) Install vscode https://code.visualstudio.com on your local machine;

(2) Install the extension Remote - SSH: https://marketplace.visualstudio.com/items?itemName=ms-vscode-remote.remote-ssh;

(3) ssh into the login node glogin9 via vscode. In order to do this, add a config file (a template config is provided in the repo conda) under ~/.ssh/config and ssh into the login node via the Command palette on vscode (keyboard shortcut cmd + ^ + p on mac) by using the option "Remote-SSH: Connect to Host...". Please add both the entries as in the config file provided, i.e., "Host hlrn ..." as well as "Host hlrn-*".

Doing this creates a .vscode-server folder on the login node that you will need to use the vscode frontend on your local machine and to develop on the assigned GPU compute note on the cluster.

2.1 Submit an interactive job to slurm

One way for using the environment is to allocate a node via an interactive job (srun) to slurm. This is normally used for developing and debugging.

(1) Use a command like this and adjust it to your needs: srun --pty -p grete:interactive -G 2g.10gb:1 /bin/bash. More info about interactive use and GPU slicing can be found here

(2) Now you can activate your conda environment in the vscode terminal and run scripts, use the vscode debugger or work with jupyter notebooks by choosing your environment as the respective kernel.

2.2 Submit a batch job to slurm

Another way for using the environment is to submit a batch job (sbatch) to slurm. This is normally used for more stable scripts, that need less developing, debugging and testing.

(1) Use the conda/example.sbatch file that is provided and adjust it to your needs. You can activate your enviromment within the sbatch file (conda/mamba activate ...), load modules (module load ...) and run for example python scripts (py ./path/to/script.py). More information can be found here.

(2) Submit your job to slurm by sbatch example.sbatch. You can check the status of the slurm job and your allocated compute node with squeue --me.

You can also directly remote ssh into the compute node via vscode locally, where you can activate your conda environment in the vscode terminal and run scripts, use the vscode debugger or work with jupyter notebooks by choosing your environment as the respective kernel. In order to do this, open the Command palette on vscode (keyboard shortcut cmd + ^ + p on mac) by using the option "Remote-SSH: Connect to Host..." and type in hlrn-<compute-node-name> and hit enter. This should open a new vscode window on the compute node.

We recommend you familiarize yourself with slurm an slurm commands, which will help you see (a) what nodes are available, (b) how to check your running jobs, (c) how to read the output and logs, (d) how to change the sbatch file in order to customize your requirements (such as needing more GPU nodes), etc. Please see the slurm documentation page for more: https://slurm.schedmd.com.

Storage on the servers

Quotas are used to limit how much space and how many files users and projects can have in each data store. To see the quotas for any data stores your current user has access to, use the command show-quota (for more details, see https://docs.hpc.gwdg.de/how_to_use/the_storage_systems/quota/index.html).

Credits to Pedro Costa Klein for helping create this document.

About

Onboarding to NHR/HLRN cluster usage

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •  

Languages