Skip to content

Accessing the course server(s)

Last updated: 1/26/2024

This document describes server resources and how to connect for development.

Applicable to local machine: Windows, Linux, & Mac

hardware specs OS
granger1.cs.virginia.edu Dual Xeon 2630v4 Broadwell (10c20t), 20 cores Ubuntu 20.04 LTS
granger2.cs.virginia.edu Dual Xeon 2630v4 Broadwell (10c20t), 20 cores Ubuntu 20.04 LTS
  • VPN: If you are off the grounds, you must connect the UVA VPN first. These servers are behind the campus firewall.

  • Login credentials: Use your CS account (NOT your UVA computing ID/password).

  • Forgot password? https://www.cs.virginia.edu/wiki/doku.php?id=accounts_password

  • For non-CS students without CS server accounts, email cshelpdesk@virginia.edu asking for creating an account, stating that you are in CS4414 and need access to granger1/2

  • Server storage: home directories are shared, meaning that files modified on granger1 will be available on granger2, as well as other CS servers like portal.

  • Load balance: As the semester begins, TAs may inform you which server you should use primarily.

Note to Windows machine owners

Your machine has two separate SSH clients (with separate configurations).

Windows native SSH client. It's a Windows program. Configuration: c:\users\%username%\.ssh\

When you type ssh from CMD or PowerShell, this is what you will invoke.

This is also what VSCode's remote explorer will invoke. It will load the above configuration file. If VSCode SSH won't work, this SSH client needs to be configured (read on).

WSL's SSH client. It's a Linux program in the WSL virtual machine. Configuration: (inside WSL): ~/.ssh/

It is only invoked if you type ssh within WSL environment. VSCode's remote explorer is not concerned with this SSH client.

Step 1: Terminal over SSH

Reference: CS wiki https://www.cs.virginia.edu/wiki/doku.php?id=linux_ssh_access

The picture below shows: from a local terminal (e.g. called "minibox"), connecting to a course server by simply typing ssh granger1. Read on for how to configure.

1.1. Use key-based authentication in lieu of password

In the example below:

  • "granger1" is used. Replace it with "granger2" as needed.
  • Windows owners:
  • to configure Windows native ssh (needed by VSCode in p1), use configuration path c:\users\%username%\.ssh\; type commands from Windows CMD or PowerShell
  • to configure WSL ssh (needed by future projects), use configuration path ~/.ssh; type commands from the WSL shell.
  • you are recommended to configure both.

The pub key on your local machine is at ~/.ssh/id_rsa.pub. Check out the file & its content. If it does not exist, generate a pub key by running ssh-keygen.

# on the local console -- Mac, Linux, or Windows (WSL/CMD/PowerShell)
$ ssh-keygen
Generating public/private rsa key pair.
Enter file in which to save the key (/home/xzl/.ssh/id_rsa):

Now, append your public key to granger1 (~/.ssh/authorized_keys). A quick way is by command ssh-copy-id. For instance:

# copy the pubkey from your local machine to granger1
$ ssh-copy-id xl6yq@granger1.cs.virginia.edu
(... type in password ...)

# next time, it should no longer ask for password
$ ssh xl6yq@granger1.cs.virginia.edu

Troubleshooting: the server still asks for password?

Still use granger1 as an example.

  • On granger1, check the content of ~/.ssh/authorized_keys. You should see your public key saved there. For instance, mine is:
$ cat ~/.ssh/authorized_keys
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCkkCZ2PO7GdX5CBL26zcIFz4XgMiHSQjaU32evuidvMXsC
ZExT9QHl3Ou00QfuagmfebugxB0aruGAsKmBxEBmlj0r1uAVCekYaIn8IPA5jynQnDRDdIABaZBWlsPx9jKo
KQqLlKgdG4JziQOAr0HaUgr+oIXgRUq7V/W1OhV9SQVF+vcIy8vVwNdLBNdbw/GtU0oKb76yxfXOC/VZM7eZ
xhovb/J450U5Op8tL/+Lg5x2sJKqR2juCFAicGbVNuXXazEDrXHgDQp+WQS8rYK4Zs95KqAsMfxvsFSbs8lf
h0pIs+sozBNUt+1noJkcyLfxhzu0yGEsxMULHE/KdAst xl6yq@portal03                        
  • On granger1, check the permission of ~/.ssh. It should be:
$ ls -la ~ | grep .ssh
drwx------ 

Check the permission of ~/.ssh/authorized_keys. It should be:

$ ls -l ~/.ssh/authorized_keys
-rw------- 

If none of the above works, you can put ssh in the verbose mode to see what's going on. From your local machine, type

ssh -vv granger1.cs.virginia.edu

Explanation: -vv tells ssh to dump its interactions with granger1 on negotiating keys. As a reference, my output is here. At the end of the output, you can see granger1 accepts my key offered from portal.

Note to Windows Users: the native ssh-copy-id.exe (the one you invoke from PowerShell or CMD) was reported to show caveats. See here. Not sure if it fixed in newer Windows. If no luck, consider manual copy & paste the key.

1.2. Save connection info in SSH config

Append the following to your ssh client configuration (~/.ssh/config). Replace USERNAME with your actual username:

Host granger1
   User USERNAME
   HostName granger1.cs.virginia.edu

Host granger2
   User USERNAME
   HostName granger2.cs.virginia.edu   

With the configuration, you can type from your local machine:

$ ssh granger1
# or 
$ ssh granger2

Step 2: Remote development with VSCode

Below we use Windows as the local machine example. Linux/Mac should be similar (even fewer caveats)

End results: being able to develop, compile, and do version control -- all from the VSCode IDE.

image-20210124192213976

We will use VSCode's official Remote.SSH extension, which will connect to the course server using Windows native SSH. An official tutorial is here.

To do so you install the "Remote development" package which will install the "Remote.SSH" extension for VSCode.

After installation, click "Remote Explorer" on the left bar. The extension will pick up your ssh config file (again that's C:/Users/%USERNAME%/.ssh/config) and present a list of hosts recognized. Click one to connect to it. The extension will copy a bunch of stuffs to the host and launch some daemon on the host. Then you are connected.

Warning - 3rd party VSCode extensions

When opening a large codebase on the server, these extensions may consume lots of resources and hang the server. This happened repeatedly before.

If that happens, TAs have to manually kill your server processes.

Windows owners: ssh keys

The extension (Remote.SSH) will invoke Window's ssh client (c:\Windows\System32\OpenSSH\ssh.exe).The Window's ssh client expects its config file at C:\Users\%USERNAME%\.ssh\config. This is NOT the ssh client you run from WSL.

If you haven't generated your SSH keys so far, you can do so by launching a PowerShell console and run ssh-keygen there.

Launch PowerShell ssh-keygen in PowerShell Access WSL root

Or, you can you copy existing ssh keys and config (e.g. from WSL ~/.ssh/) to the location mentioned above. Btw, the way to access WSL's root filesystem is to type \\wsl$ in the explorer address bar. See the figure above.

Launch a terminal

After connection, click "remote" on the left bar to bring up a remote terminal, in which you can execute commands to build projects, etc. Make sure to click the "+" sign to create a new shell terminal.

image-20210124192109456

File browsing & editing

Then you will specify a remote folder on the server to "open":

image-20210124192002504

To browse & edit files on the server, click "explorer" on the left bar

image-20210124192213976

Click "source control" on the left bar for a handy git interface.

Copy files to/from the server

Just drag and drop the files between VSCode's file list and your local directory.

Troubleshooting

Things like Windows auto update may break VSCode's ssh configuration that worked previously. In this case, try deleting (or moving to other places) the .vscode-server folder on the course servers (under the p1-kernel/ directory), close all remote connections, and close the local VSCode program. Then start from a clean slate.

If things still break, seek help from the online discussion forum. Provide the following information:

  • the error message of VSCode
  • the PowerShell output when you try to connect to granger1 from the PowerShell command line. Have you tried granger2?
  • any recent Windows/VSCode updates?
  • any other relevant information