This lesson is in the early stages of development (Alpha version)

Introduction to Using the Shell in a High-Performance Computing Context: Setup

Suggested desk setup

In the workshop you will need to view:

We therefore recommend you have two screens set up if possible.

Required credentials

Before the workshop you should receive three things you will need to log on to the high-performance computing cluster used during this workshop:

  1. A file called something like userXX, where XX is two digits;
    • This is your encrypted SSH private key - keep it secure.
  2. A file called something like userXX.pub, where XX is two digits;
    • This is your SSH public key.
  3. A passphrase (password)
    • This string of characters is needed to decrypt and use your encrypted SSH private key (see above) - keep it secure.

Save the two files to the machine you will be using the workshop.

The purpose of these three things will be explained in the workshop.

Required software

There are several pieces of software you will wish to install before the workshop. Though installation help will be provided at the workshop, we recommend that these tools are installed (or at least downloaded) beforehand.

VS Code

You may need a text editor on your machine. This should be something like

FileZilla Client

This is for copying files between your machine and the remote cluster. Download the FileZilla client from here.

Bash and SSH

This lesson requires a terminal application (bash, zsh, or others) with the ability to securely connect to a remote machine (ssh).

Where to type commands: How to open a new shell

The shell is a program that enables us to send commands to the computer and receive output. It is also referred to as the terminal or command line.

Some computers include a default Unix Shell program. The steps below describe some methods for identifying and opening a Unix Shell program if you already have one installed. There are also options for identifying and downloading a Unix Shell program, a Linux/UNIX emulator, or a program to access a Unix Shell on a server.

Windows

Computers with Windows operating systems do not automatically have a Unix Shell program installed. In this lesson, we encourage you to use an emulator included in Git for Windows, which gives you access to both Bash shell commands and Git. If you have attended a Software Carpentry workshop session, it is likely you have already received instructions on how to install Git for Windows.

When you install Git for Windows you’re asked a number of questions; we recommend the followng responses:

Once installed, you can open a terminal by running the program Git Bash from the Windows start menu.

Alternatives to Git for Windows

Other solutions are available for running Bash commands on Windows. There is now a Bash shell command-line tool available for Windows 10. Additionally, you can run Bash commands on a remote computer or server that already has a Unix Shell, from your Windows machine. This can usually be done through a Secure Shell (SSH) client. One such client available for free for Windows computers is PuTTY. See the reference below for information on installing and using PuTTY, using the Windows 10 command-line tool, or installing and using a Unix/Linux emulator.

For advanced users, you may choose one of the following alternatives (but we would really prefer you to use Git for Windows for this workshop):

Warning

Commands in the Windows Subsystem for Linux (WSL), Powershell, or Cygwin may differ slightly from those shown in the lesson or presented in the workshop. Please ask if you encounter such a mismatch — you’re probably not alone.

macOS

On macOS, the default Unix Shell is accessible by running the Terminal program from the /Application/Utilities folder in Finder.

To open Terminal, try one or both of the following:

Reference

How to Use Terminal on a Mac

Linux

On most versions of Linux, the default Unix Shell is accessible by running the (Gnome) Terminal or (KDE) Konsole or xterm, which can be found via the applications menu or the search bar.

Special cases

If none of the options above address your circumstances, try an online search for: Unix shell [your operating system].

SSH for Secure Connections

All students should have an SSH client installed. SSH is a tool that allows us to connect to and use a remote computer as our own.

Windows

Git for Windows comes with SSH preinstalled: you do not have to do anything.

GUI Support (optional)

None of the software we will be running in the workshop requires a graphical user, but if you do want to run graphical applications on remote machines via SSH in the future then please install MobaXterm Home > Edition.

macOS

macOS comes with SSH pre-installed: you do not have to do anything.

GUI Support (optional)

None of the software we will be running in the workshop requires a graphical user, but if you do want to run graphical applications on remote machines via SSH in the future then please install XQuartz.

Linux

Linux comes with SSH and X window support preinstalled: you do not have to do anything.