!!! THIS DOCUMENT HAS BEEN MOVED TO HERE. This version will be deleted.
This document is written specifically to introduce students to the slurm cluster at the DSI at the University of Chicago. It is general enough, however, that many parts should be useful for even experienced slurm users and general remote computing. If a part is unclear or you have additional tips, please open an issue or pull request!
Please read all portions carefully and only skip if you really know what you are doing. If you come across an issue, check that it isn't addressed in Troubleshooting before asking.
Research institutions often have computing clusters that can be used to perform tasks that are too instensive to be run on a typical laptop. Examples are high RAM operations and operations that are much more efficient on GPUs. A computing cluster is a collection of computers (also referred to as nodes, machines, or servers) that you are 'in the cloud' (you are not physically at one of them when using them). You are able to log into the head node (also called login node) with an internet connection using ssh. If you have an account you can use ssh username_here@address_of_machine
to connect. You will then have to authenticate by proving you have access with either something only you know (a password) or something only you have (a private key -- see public key cryptography if interested). Once you have successfully authenticated you will see your command prompt change (the text at the bottom left of your terminal that looks something like username@computer:~/filepath
-- this is fully customizable if interested) to show the username you logged in with at the hostname of the machine's login node (or head node) (for the ai or dsi cluster this will be fe0n
where n is a digit). From here you will have access to your own directory. The login node should just be used for low computation tasks like file management, writing code, and extremely simple programs. Everyone using the cluster will login to the same set of login nodes so if you try to run a complex program, it will slow it down for everyone (and you'll recieve an email asking you to stop).
Logging in through the command line makes it so all commands you run in that terminal are executed on the remote machine. But command line editors (like vim and emacs) can have a significan learning curve compared to editors like VS Code. For this reason we will use a VS Code extension that allows you to connect your whole VS Code window to the cluster (and utilize all of VS Code's nice features and extensions). Instructions are located below.
- Part I: Prerequisites
- Part II: Set up SSH
- Part III: SLURM and Cluster Basics
- Part IV: Clone Repository
- Part V: VS Code
- Part VI: Conda
- Part VII: Submitit
- Troubleshooting
- Appendix
This guide is specifically tailored to the University of Chicago DSI Cluster, though it should be generally applicable to most slurm clusters. The guide assumes you have:
- A CNET id
- A CS Account. Get one here if you don't have one already.
- (for Part 3 onward) Access to a slurm partition. To request, send an email to [email protected] asking for access to compute nodes on the DSI cluster and cc your mentor (if relevant)
- A reasonably up to date and functioning computer running on Windows (10/11), Mac (10.13+/High Sierra+), or Linux.
- An internet connection. You'll need internet to use ssh.
- VS Code
- A GitHub account
It can be annoying / burdensome to type in your passwords constantly to connect to the cluster or push/pull from GitHub. We can switch to authunticating based on something we have using ssh keys.
If you are using Windows 10 or 11, you can use OpenSSH like Mac and Linux users. If you use WSL2, please see specific instructions. To ensure it is set up correctly, complete the following (from this SO answwer):
- Open Manage optional features from the start menu and make sure you have Open SSH Client in the list. If not, you should be able to add it.
- Open Services from the start Menu
- Scroll down to OpenSSH Authentication Agent > right click > properties
- Change the Startup type from Disabled to any of the other 3 options. I have mine set to Automatic (Delayed Start)
- Open cmd and type where ssh to confirm that the top listed path is in System32. Mine is installed at C:\Windows\System32\OpenSSH\ssh.exe. If it's not in the list you may need to close and reopen cmd.
- You should know be able to access OpenSSH tools from the Windows Command Prompt. Continue to General Instructions.
- In the terminal of your local computer (or if on windows, Command Prompt), use
ssh-keygen
, instructions here. Recommended: usessh-keygen -t ecdsa -b 521
orssh-keygen -t ed25519
to generate your key. - If you have multiple keys, give it an identifiable name but keep it in the
.ssh
directory. Otherwise you can click enter to accept the default suggestion. - You can optionally add a password to your ssh key. If you do not it may be vulnerable. Adding a password may seem counterintuitive (isn't our whole goal to avoid passwords?), but you can use ssh-agent (explained below) and then you will just have to type your password once per session (or once ever). As you type the password in, no text will appear on screen to keep your password length private from shoulder surfers. You will be asked to repeat it. Do not forget your password! Write it down, or ideally store it in a password manager. A
KEYNAME
andKEYNAME.pub
file will be created by this command. The file with the.pub
extension is your public key and can be shared safely. The file with no extension is your private key and should never be shared. - (assuming you password protect your private key) Add the key to your ssh agent.
ssh-add PATH_TO_KEY
.PATH_TO_KEY
will start with~/.ssh/
on Mac/Linux andC:\Users\YOUR_USERNAME\.ssh\
on Windows. You'll have to type your password in once and it will be saved for a period of time (terminal session or until your computer next reboots), drastically limiting the amount of times you have to type in your password. - [Mac Users Only] (optional) To keep the key in your ssh-agent accross sessions, follow this stack overflow answer
- Confirm your key was added. In your terminal/command prompt/powershell, run
ssh-add -l
to list all keys in your ssh agent. Your key should appear here. If this command returnsThe agent has no identities.
, step 4 failed.
- Create / modify your SSH Config. Typing in the full ssh command is now something like
ssh -i PATH_TO_KEY [email protected]
which can be a lot to type and a lot to remember. Using ssh config, we can reduce this to justssh fe.ds
. In your.ssh
directory create aconfig
file if one does not exist. To open:- [Windows] In command prompt:
code C:\Users\USERNAME\.ssh\config
whereUSERNAME
is your windows username. - [Mac] In a terminal:
touch ~/.ssh/config
to create the file if it does not exist andopen ~/.ssh/config
to open it. - [Linux] In a terminal:
code ~/.ssh/config
- [Windows] In command prompt:
- You may or may not already have configurations saved. Place this text in the config file, after any other configurations, except any block that starts with
Host *
orHost fe01.ds.uchicago.edu
:
Host fe.ds*
HostName fe01.ds.uchicago.edu
IdentityFile INSERT_PATH_TO_PRIVATE_KEY
ForwardAgent yes
User INSERT_YOUR_CNET
Host *.ds !fe.ds
HostName %h.uchicago.edu
IdentityFile INSERT_PATH_TO_PRIVATE_KEY
ForwardAgent yes
User INSERT_YOUR_CNET
ProxyJump fe.ds
Replace INSERT_YOUR_CNET
with your CNET ID and INSERT_PATH_TO_PRIVATE_KEY
with the path the key you previously created. This will map fe.ds
to an ssh command to the listed hostname, with the listed user and private key, and using the listed identity file as your key. ForwardAgent
set to yes means that any ssh keys added to your local agent will also be added to the remote machines ssh agent (so you can use your local ssh key for GitHub on the cluster, for example). The second block is for connecting directly to compute nodes.
- Save and close the file.
For a private key to work for authenticating, the service you are authenticating with must have access to your public key. We will set this up for github and the cluster.
- Print your public key:
- [Windows] In command prompt:
type C:\Users\USERNAME\.ssh\KEYNAME
whereUSERNAME
is your Windows username andKEYNAME
is the key your created. - [Mac/Linux] In a terminal:
cat ~/.ssh/KEYNAME.pub
whereKEYNAME
is the key you created.
- [Windows] In command prompt:
- Copy your public key. Highlight and copy the entire output.
ctrl+c
may not work in terminal.ctrl+shift+c
or right click may work. - Add public key to GitHub. To give GitHub access to your public keys, go to GitHub's ssh keys page.
- Click 'New SSH key'. Give it a name relating to the machine it is storeed on, like "windows laptop", or "linux desktop" and paste in the full contents of the public key.
- Verify your key was added. In terminal / command prompt, try
ssh [email protected]
it should respond withHi GITHUB_USERNAME! You've successfully authenticated, but GitHub does not provide shell access.
or something similar.
- If on Mac/Linux, you can use
ssh-copy-id -i ~/.ssh/KEYNAME_HERE.pub fe.ds
, replacingKEYNAME_HERE
with the name of the public ssh key you would like to use (it should end with .pub). - You will be prompted for
[email protected]
's password. This will be your CNET password. - To verify success: In your terminal,
ssh fe.ds
should connect you to the cluster without typing any password.
- Copy your public key. Follow Step 4: Enable Authentication with SSH Keys steps 1 and 2 again.
- Now connect to the server. Do
ssh fe.ds
. You'll have to type in your UChicago password. Your command prompt is now attached to the login node. The bottom left of your screen should say something likeUSERNAME@fe01:~$
. - Ensure there is an
.ssh
directory. Runmkdir .ssh
. - Add your public key to the list of authorized keys. Run
echo "PUBLIC_KEY_HERE" >> .ssh/authorized_keys
, replacingPUBLIC_KEY_HERE
with the copied public key and maintaining the quotations. ctrl+v may not paste in your terminal. Try right clicking, ctrl+shift+v, and shift+insert. - Type
exit
to exit the cluster and return to your windows command prompt. - To verify success: In your command prompt,
ssh fe.ds
should connect you to the cluster without typing any password.
You can now successfully and easily connect to the cluster in your terminal! Congratulations, this is not a trivial task. Lets run through some cluster and SLURM basics.
- Connect to the cluster using
ssh fe.ds
- By default, you start with your working directory in your home directory. This is located at
/home/USERNAME
whereUSERNAME
is your CNET ID and shortened to~
. Run the commandpwd
to print your current working directory. The computer you are logged into runs on linux and the filesystem is similar to Mac and other linux filesystems.ls /
will show you the contents of the root directory and it will look similar to that of a personal computer. This system however might be spread across many physical machines and is shared by many users.ls /home
will list all users home directories. You only have permission to view or modify files in yours. The home directory is where you will store all repositories and data you do not want to share. Home directories on this system are limited to 20 GB of storage. - Run
ls /net/projects
to view a list of shared project directories. These are folders for sharing large data and often have storage of hundreds of GBs. To have access to one of these folders, you must be a member of its unix group.ls -l /net/projects/
will list all of the content directories, this time with more information. The first column looks likedrwxrwxr-x
and refers to the permissions for the file/directory. Then there is a number, then the user that owns the file. Then the group the file belongs to. To see what groups you are a member of, runid USERNAME
whereUSERNAME
is your CNET ID. - Run
ls /net/scratch
to view a space where projects keep their data. Runls -l /net/scratch
to see permissions, user and group owners, size, and date created. This space can retreive and store data quicker than/net/projects
but its design is more temporary. This directory will be cleaned at the end of each quarter, meaning idle and long untouched files will be deleted. - Run the command
htop
. This shows you the memory usage, cpu utilization, and processes running on the login node. As you can see, many users are on here concurrently. So if one tries doing something too intensive, it will slow it down for everyone (and they will know who did it). Be courteous. Press q to exit.
When you want to run an intensive job, use a compute node. These are powerful computers with GPUs, powerful CPUs, and/or lots of memory. In order to fairly share them among all users, slurm manages a queue system. Users submit requests of what resources they need and when they become available, slurm grants access. Here is uchicago's documentation on slurm.
- Run
sinfo
to see what nodes are on the cluster. The first columnPARTITION
will list adev
andgeneral
partition and maybe more. Partitions are just different sets of nodes that different groups of users may have different access to.TIMELIMIT
is the longest job you can run on a particular partition andNODES
is the number of nodes in the partition. - Run
squeue
to see the state of the queue. If any jobs are currently running, it will show its JOBID, the PARTITION it is on, what USER owns it, the state of the job (ST column. R = Running, PD = Pending, CG = Completing), and the NODELIST of nodes it is using. - To submit a job request, we'll use
srun
.srun
is for interactive jobs (sinteractive
is an alias for something similar to this) that allow us to interact with our code while it is attached to the compute node.srun
has many configurable options, here are the ones we'll use most:-t
or time. The duration of the allocation. can be of the format# of minutes:# of seconds
so-t 240:00
would request a node for 240 minutes.--mem
or memory. The amount of memory/RAM you would like. By default a number is read in KBs, but by ending with G it is read in GBs. So--mem 1000
would request 1000 KBs and--mem 16G
would request 16 gigabytes.-p
or partition. Usegeneral
for interactive jobs.--gres
or 'generic resources' is what we use to request gpus.--gres=gpu:1
will request a single gpu.--pty
is added to attach to the process in a pseudoterminal.
- Run
srun -p general -t 5:00 --mem 1G --pty /bin/bash
to request a compute node. - Now your terminal is connected to the compute node. Notice that
ls
andpwd
give the same results as before. This is because the compute nodes and login nodes use the same filesystems. If you edit a file in one, the second it is saved it will be visible in the other. Typeexit
to end your job and return to a login node. You can also cancel a job by runningscancel JOB_ID
.
- Go to the repository github page, click the dropdown on the green button that says 'Code', select 'SSH' and copy the value.
- Connect to the login node.
ssh fe.ds
- In login node:
git clone COPIED_VALUE
will clone the repo.
VS Code is a code editor with a rich collection of very useful extensions. It is well worth the time learning how to use these extensions for maximum benefit. Remote - SSH
is a VS Code extension that allows you to open a connection to a remote machine in VS Code. Traditionally, one would ssh
in a terminal and be restriced to command-line text editors like Vim. Remote - SSH
allows us to act like we are developing on our local machine as normal for the most part and has less of a learning curve.
-
Install
Remote - SSH
. Click 'Extensions' on the menu at the left side of VS Code (its icon is four squares with the top right one pulled away). Search for and installRemote - SSH
-
Add useful extensions to always be installed in remote connections. Open the command palette (ctrl+shift+p / command+shift+p / View -> Command Palette...) and search for
Open User Settings
. If it is empty, paste:
{
"remote.SSH.defaultExtensions": [
"ms-toolsai.jupyter",
"ms-toolsai.jupyter-renderers",
"ms-python.python",
"ms-python.vscode-pylance"
]
}
otherwise, make sure to add a comma to the end of the current last item and add the following before the }
:
"remote.SSH.defaultExtensions": [
"ms-toolsai.jupyter",
"ms-toolsai.jupyter-renderers",
"ms-python.python",
"ms-python.vscode-pylance"
]
- Follow the instructions here to set up with the following modifications:
- In "Connect to a remote host", try
Remote-SSH: Connect to Host...
and you should seefe.ds
as an option. Select it. Otherwise, you can try typing infe.ds
. - The type of server is Linux.
- In "Connect to a remote host", try
- The (usually green) box at the bottom left of your VS Code window should now say
SSH: fe.ds
to signify you are using the SSH extension and connected to the hostfe.ds
. You clickFile
thenOpen Folder
and select your repository folder. The window will reload and the files of the repository will be visible if you go the Explorer tab on the top left of VS Code. You can open a terminal in the VS Code window by clickingTerminal
in the top menu, thenNew Terminal
. - Close the window. Now if you open a new VS Code window and select from recent, the one called `REPOSITORY_NAME [SSH: fe.ds] will take you right to the login node of the cluster with your previous configuration.
- Open a terminal / command prompt. Do
ssh fe.ds
. - You should now be connected to the cluster in a login node, which is fine for small tasks and coding. To get access to a powerful compute node, you must request access through slurm. Request an interactive session with a command like:
srun -p general --gres=gpu:1 --pty --mem 1000 -t 90:00 /bin/bash
. Once you have been your request has been granted, your command prompt will change to something likeUSERNAME@hostname
where hostname is probably likeg004
. - Now your terminal is connected to a compute node. (NOTE: If you did this in a terminal in VS code, just that terminal will connect to a compute node. The rest of VS Code functionality will be run on the login node still. To connect VS code features like python debug and notebook editing to the compute node follow along).
- Back in VS Code, open the command palette (cntr+shift+p / command+shift+p / View -> Command Palette...), search for
Remote-SSH: Connect to Host...
. Select it and type in as your hostHOSTNAME.ds
replacing theHOSTNAME
with the hostname from above. - Your VS Code should now be connected to the compute node. To verify the You'll have to open the repository folder (see below instructions for cloning). But now you can take advantage of the computational power from the node and the nice features of VS Code (using notebooks, python debugging, etc.)
- Connect to cluster
- In a terminal on the cluster:
wget https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-x86_64.sh -O ~/miniconda.sh
bash ~/miniconda.sh
You can accept the defaults. Make sure you select yes when it asks to run conda init. This will ensure conda is activated by default. re-open and close your terminal.
- Create a new environment
conda create --name PROJECT_NAME python=3.9
conda activate PROJECT_NAME
pip install -r requirements.txt
Where PROJECT_NAME
is the name of the project you are working on. Now when you log into ai cluster, just make sure you run conda activate PROJECT_NAME
.
-
Ensure VS Code uses the correct python environment. When a python file is open and selected, click the Python version number on the bottom right and select the interpreter for PROJECT_NAME. If it is not listed, the path is:
/home/USERNAME/miniconda3/envs/PROJECT_NAME/bin/python
whereUSERNAME
is your CNET ID. -
Ensure VS Code uses the correct kernel for Jupyter notebooks. First, install
ipykernel
in thePROJECT_NAME
environment:
conda install -n PROJECT_NAME ipykernel --update-deps --force-reinstall
With a Jupyter notebook open, click the Python version number in the upper right and select the kernel for PROJECT_NAME
. You may need to refresh the list of available kernels using the icon in the upper right of the menu.
- You should now be at a point where you can easily connect to the cluster with VS Code, use jupyter notebooks, and attach to compute nodes for more intensive jobs. This is enough for a lot of tasks, but if you become bothered by long running jobs crashing due to internet connection outages or running out of time on the compute node, please continue to using submitit.
The commands to remember are:
sinfo
for information about the clustersqueue
for information about currently running or queued jobssrun
to run a job interactivelysbatch
to submit a job to the queue (we'll use submitit for this)scancel
to cancel a job. Usescancel JOB_NUMBER
We'll use submitit to actually submit jobs in python.
When we use slurm, we must be respectful to not overuse nodes. Please:
- To test code, submit it to the
dev
queue or test them with less data in an interactive session - Don't run computation heavy jobs on the login nodes. Submit them as jobs
- Do not submit many jobs at once
- To run code you are confident works, submit it to the
general
queue
To understand how we use submitit, some background knowledge will be useful:
if __name__ == "__main__":
blocks. The code under these blocks will run when the file is run as a script and not when it is imported as a module. For more information, see this- Command Line Arguments. When you run something as a script, adding command line arguments can allow you to modify arguments without going into your python code. We'll use a package called argparse to convert command line arguments into easily parsable python objects. For more information, see this tutorial and argparse documentation
- JSON. We'll use the json file format to store configuration. This is basically like a python dictionary.
To make use of submitit, a long script with no functions or a jupyter notebook will not work. You will need to think of how to write your code in a manner that is more abstract by using python functions and classes. Your code should be: ready for change, easy to understand, and safe from bugs. There are plenty of good resources on software design. For the bare minimum to work with submitit:
- Move the code you wish to run on the compute node into a single function (which will ideally contain well designed and documented helper functions). For example, you'd want to turn something like this:
import pandas as pd
df = pd.read_csv("test.csv")
df = df[df["year"] > 2004]
average = df["amount"].mean()
print(average)
into a function that is general (hint: if a descriptive name of your function is very long, you may want to make it more general) and return results instead of printing. Do this:
import pandas as pd
def get_mean_amount_after_year(path_to_csv: str, earliest_year: int):
""" Return mean value of 'amount' column with year > earliest_year """
df = pd.read_csv(path_to_csv)
df = df[df["year"] > earliest_year]
return df["amount"].mean()
Submitit eliminates the need to remember complicated and long configurations and allows us to work only in python. The sample program in main.py
runs a test version.
- Add a
if __name__ == "__main__":
block at the end of your python file. No submitit code should exist in your actual function. This way we can easily pivot between submiting jobs with submitit and local exucution. Call your function here. - Create a JSON file with configuration information. Include a "slurm" key that maps to a dictionary with slurm configuration options that start with
slurm_
rather than the--
you use on the command line. Include asubmitit
key that maps to true when you want to submit the job and false when you want to run it normally (either locally or for debugging). Finally include any arguments to your python function. For example:
{
"path_to_csv": "test_file.csv",
"earliest_year": 1994,
"submitit": true,
"slurm": {
"slurm_partition": "general",
"slurm_job_name": "sample",
"slurm_nodes": 1,
"slurm_time": "60:00",
"slurm_gres": "gpu:1",
"slurm_mem_per_cpu": 16000
}
}
- Add argparse. I like to use
argparse
to submit a path to a query that contains both all slurm configuration and asubmitit
key that maps to a boolean. Your file will look something like this:
from pathlib import Path
# your actual code will have more and longer functions than this sample
def get_mean_amount_after_year(path_to_csv: str, earliest_year: int):
""" Return mean value of 'amount' column with year > earliest_year """
df = pd.read_csv(path_to_csv)
df = df[df["year"] > earliest_year]
return df["amount"].mean()
if __name__ == "__main__":
import argparse
import json
# set up command line arguments
parser = argparse.ArgumentParser()
parser.add_argument(
"--query", help="path to json file containing query", default=None
)
args = parser.parse_args()
# read in query
if Path(args.query).resolve().exists():
query_path = Path(args.query).resolve()
else:
# throw
raise ValueError(
f"Could not locate {args.query} in query directory or as absolute path"
)
with open(query_path) as f:
query = json.load(f)
# save query parameters to variables. if you want a default, better to put
# at the outermost call to a function.
path_to_csv = query.get("path_to_csv")
default_earliest_year = 2005
earliest_year = query.get("earliest_year", default_earliest_year)
output_directory = Path("results").resolve()
executor = submitit.AutoExecutor(folder=output_directory)
# here we unpack the query dictionary and pull any slurm commands that
# are in 'slurm' key. For more info on the ** syntax, see:
# https://stackoverflow.com/a/36908. The slurm options here are the same
# as those you use on the command line but instead of prepending with '--'
# we prepend with 'slurm_'
executor.update_parameters(**query.get("slurm", {}))
# if submitit is true in our query json, we'll use submitit
if query.get("submitit", False):
executor.submit(
get_mean_amount_after_year,
path_to_csv,
earliest_year,
)
else:
get_mean_amount_after_year(
path_to_csv,
earliest_year,
)
Then with a query like this:
you can run python path/to/script.py --query path/to/query.json
and get your result.
- Make sure you save your results in some way! Otherwise your script might run perfectly but be the results will be completely lost. This sample script will compute the mean but not save it anywhere. Save it to a file or log it.
- Using submitit. IMPORTANT: you run submitit on a login node to submit to a compute node. You can run your python file from the command line.
- Debugging submitit. Before you submit a long, multi hour job, test on a smaller dataset interactively. For this you can attach to a compute node, and run your script but with the
submitit
flag in your query json set to false. To debug, use the VS Code debugger. Add command line arguments to the debugger by following these instructions
There are a lot of steps here and its easy to miss something or discover a gap in the docs. Here are some common errors, and troubleshooting steps you can take.
Error: srun: error: Unable to allocate resources: Invalid account or account/partition combination specified
Cause: You do not have permission to use the partition you requested from.
Solution: Most likely you need to email [email protected] requesting access to compute nodes. Otherwise check that you are requesting the correct partition (currently there is only dev
and general
. The default if unspecified is the dev
partition).
Error: CUDA out of memory
Cause: The GPU you were using ran out of RAM.
Solution: Could be difficult to solve completely, but there are few things that usually work:
- Easy: Simple refactoring. Use less GPU by reducing batch sizes, for example.
- Medium: Try using another GPU with more memory. To see GPU's available, run
sinfo -o %G
. You can look up the models online. You can request a specific GPU with the--gres=gpu:GPU_NAME:1
flag whereGPU_NAME
is the type of gpu (likea40
) - Hard: Major refactoring of your code to use less memory.
Error: Killed
or Out of Memory
on compute node
Cause: Most likely, you ran out of CPU memory
Solution: Request more memory! Use the --mem
flag on srun
Error: Disk quota exceeded
Symptom: VS code fails to connect to login node
Cause: Each home directory has a quota of disk storage space (~50 GB) and you are above it.
Solution: You need to move or delete some files on your home directory. If you are working on a project with a /net/projects/
directory, move any data files or checkpoints into that directory (and update your code accordingly!). To check you disk usage, run du -sh ~
. Feel free to move some data to /net/scratch
for storage as well. Please note that this directory will be cleaned around every two months.
Error: [email protected]: Permission denied (publickey). fatal: Could not read from remote repository.
Cause: GitHub can not access a private key that matches the public key stored on GitHub.
Solution: If you are on the cluster, make sure that you are forwarding your ssh agent. ssh-add -l
should return the appropriate key. If no identities are found, your ssh-agent has no identities or is not being forwarded. If ssh-add -l
locally also returns no identities, you must run ssh-add PATH_TO_KEY
as specified in Part II, Step 2. If the correct identity is found locally, make sure your ssh config matches the one in this document. Finally make sure you have added the appropriate public key to your GitHub account.
Whenever an error comes up, think about all the potential points of failure. Then try to isolate each and see if they work on their own. For example if you are trying to connect to a compute node with VS code using the steps in these instructions, potential points of failure are: VS Code Remote - SSH
extension, VS Code, your internet connection, ssh config file, ssh keys, slurm, the cluster. Below find some methods to check if different components are working correctly.
Test: run ssh fe.ds
locally
Expected Result: successful connection to login node.
Test: run ssh -v fe.ds
locally for verbose output (add up to 3 v's for more verbosity).
Expected Result: Close to the start, you should see something like:
debug1: Reading configuration data /home/USERNAME/.ssh/config
debug1: /home/USERNAME/.ssh/config line 20: Applying options for fe.ds*
debug1: /home/USERNAME/.ssh/config line 26: Skipping Host block because of negated match for fe.ds
where USERNAME
is your username on your computer. Check that the path after Reading configuration data
is to the config file you expect and that the right Host blocks are being used. Further down you should see something like:
debug1: Authentications that can continue: publickey,password
debug1: Next authentication method: publickey
debug1: Offering public key: /home/USERNAME/.ssh/id_ed25519 ED25519 SHA256:asdkfh298r9283hkdsjfn23rhdf9284 explicit agent
debug1: Server accepts key: /home/USERNAME/.ssh/id_ed25519 ED25519 SHA256:a;sldfkj2oiefjowihoweflkdfjslfkjksld0923 explicit agent
debug1: Authentication succeeded (publickey).
Test: run ssh-add -l
locally
Expected Result: You should see something like 256 SHA256:<a bunch of characters> USERNAME@HOSTNAME (KEY_TYPE)
. If you see The agent has no identities
, you must ssh-add PATH_TO_KEY
.
Test: run ssh-add -l
on a login node
Expected Result: You should see something like 256 SHA256:<a bunch of characters> USERNAME@HOSTNAME (KEY_TYPE)
. If you see The agent has no identities
, you must ssh-add PATH_TO_KEY
.
Test: run ssh [email protected]
locally and on a login node to test GitHub ssh keys
Expected Result: Hi GITHUB_USERNAME! You've successfully authenticated, but GitHub does not provide shell access.
Test: request compute node and ssh COMPUTE_NODE.ds
where COMPUTE_NODE
is the node name (like g004
)
Expected Result: connection to the compute node
Using WSL2 on Windows is a great way to have access to a linux system on a Windows OS. The convience of 'pretending' to have two separate operating systems on one, however, can lead to complications. One is with SSH keys. The .ssh
directory used on your normal Windows system and your WSL will be different from each other. This is fine in most cases, but can lead to headaches when using VS Code. If you wish to connect to a remote SSH machine in VS code, it will use your Windows configuration. So even if you only use WSL2 and the VS Code extension (WSL) to code in WSL2, you must follw the Windows ssh instructions. If you wish use the same keys on each system, you can copy them. See this article for more information.