Getting Started with CARC OnDemand

The CARC OnDemand service is an online access point that provides users with web access to their CARC /home, /project, and /scratch directories and to the Discovery and Endeavour HPC clusters. OnDemand offers:

  • Easy file management
  • Command line shell access
  • Slurm job management
  • Access to interactive applications, including Jupyter notebooks and RStudio Server

OnDemand is available to all CARC users. To access OnDemand, you must belong to an active project in the CARC User Portal.

CARC OnDemand will only be accessible via a connection to either USC's Secure network or a USC VPN. Instructions for setting up a VPN connection can be found at the following links:

Intro to CARC OnDemand video

Log in to CARC OnDemand

Note: We recommend using OnDemand in a private browser to avoid potential permissions issues related to your browser's cache. If you're using a private browser and still encounter permissions issues, please submit a help ticket.

Files

OnDemand provides a web-based File Explorer that can be used to upload, download, copy, delete, rename, and edit files. OnDemand has quick links to your:

  • CARC home directory
  • CARC project directory(ies)
  • CARC scratch directories

Every user has access to their /home1, /scratch1, and /scratch2 directories. If you have access to a project space in a project directory, you will also have access to this directory. The project directory's name is of the form /project/<PI_username>_<project_ID>.

You can access the File Explorer from the main OnDemand dashboard. Select the directory you would like to access:

Files Dashboard

After selecting a directory (in this case, the user's home directory), OnDemand presents a graphical representation of the directory and all its contents:

Files Dashboard

Directory navigation

From your selected directory, switch to another by backtracking through the path near the top of the window and selecting the previous directory you wish to browse:

Files Dashboard

Alternatively, use Change Directory to the right of the directory path to type the path you wish to navigate to:

Files Dashboard

On the left side of the screen is a tree view of the directory structure. Navigate this tree the same way you might on a normal desktop GUI to select the folder you wish to use.

Uploading and downloading files

OnDemand provides a basic file upload/download feature. However, this should be reserved for relatively small files (e.g., scripts and log files). For larger files, use one of the applications described in our transfer guides.

There are several ways to upload files:

  • Navigate to the desired destination directory in OnDemand and then drag the file from your local computer to the OnDemand browser window.
  • Click the "Upload" button to open a dialog that allows you to navigate your local computer and select which files you want to upload.

Files Upload

To download files, select the file(s) in the OnDemand directory that you wish to download and then use the blue Download button. If you select multiple files or a folder, OnDemand will zip the files and download a single .zip archive to your computer.

File operations

Most file operations can be accomplished by selecting a file in the File Explorer and choosing the desired operation from the main menu:

Files Operations

You have the ability to perform the following file operations in OnDemand:

  • View
  • Edit
  • Rename/Move
  • Download
  • Copy
  • Paste
  • (Un)Select All
  • Delete

Jobs

OnDemand provides two related job managment tools. The Active Jobs tool allows you to monitor queued and running jobs and the Job Composer tool allows you to create and submit jobs via your web browser:

Files Dashboard

Active Jobs

The Active Jobs tool shows you all jobs currently in the queue (running or queued), regardless of how the jobs were submitted:

Files Dashboard

Use the dropdown options at the top of the page to toggle between your jobs, all jobs, and the different clusters. The screenshot above shows all jobs on both clusters. Use the Filter tool to filter jobs based on sytems (Discovery or Endeavour), status (running, queued, or hold), user, project account, etc.

Click the arrow to the left of a job entry to display more information about the job, including information about the node(s) on which the job is running.

Job Composer

Selecting Job Composer in the Jobs menu will open the Jobs page, where you can create new jobs and submit them to the cluster, and inspect the results of jobs submitted via this tool.

To create a new job using the Job Composer, from the Jobs page, select the + New Job button:

Files Dashboard

There are four ways to create a job:

  • From Default Template creates a Simple Sequential Job (the default job template)
  • From Template creates a new job by copying from an existing job template directory
  • From Specified Path creates a new job based on the source path to a directory on Discovery/Endeavour
  • From Selected Job creates a new job from a previously-run job directory

For example, to create a new job from a job template, select New Job->From Template. Next, select the job template to copy (in this case, Job Array Job), then click the blue Create New Job button on the lefthand side of the page:

Files Dashboard

The template directory will be copied and a new job row will be added to the top of the jobs table on your Jobs page:

Files Dashboard

From the table, select the job you just created, then modify and/or add any files to this job by clicking Edit Files:

Files Dashboard

In the File Explorer, upload any files required for your job. See the Files section of this user guide above for instructions on uploading files.

If you need to make changes to a job's settings, select the job and click Job Options:

Files Dashboard

Here, you can change the job name, cluster, job script, project account, or job array specification:

Files Dashboard

After you've created your job, added files, and changed any settings as necessary, submit the job using the green Submit button from the Jobs page. Use the yellow Stop button to stop a running job, or the red Delete button to delete a job from your list:

Files Dashboard

Monitor the job status on the Jobs page:

Files Dashboard

Currently, you must reload the page to see job status changes.

Shell access

OnDemand provides the ability to SSH into the Discovery, Endeavour, and Data Trannsfer clusters from inside your web browser using the Clusters tool:

Files Dashboard

Discovery cluster

To access the Discovery cluster, select Clusters->Discovery Cluster Shell Access from the dropdown.

Shell access will be connected to the Discovery login node. For detailed information on the Discovery cluster, see the Getting Started with Discovery user guide.

CARC file systems (/home, /project, /scratch1, and /scratch2) are accessible using the OnDemand File Explorer — see the Files section of this user guide above.

Endeavour condo cluster

Note: To SSH into the Endeavour cluster using OnDemand, you must belong to a CARC project with an Endeavour allocation.

To access the Endeavour cluster, select Clusters->Endeavour (condo) Cluster Shell Access from the dropdown.

Shell access will be connected to the Endeavour login node. For detailed information on the Endeavour cluster, see the Getting Started with Endeavour user guide.

CARC file systems (/home, /project, /scratch1, and /scratch2) can are accessible using the OnDemand File Explorer — see the Files section of this user guide above.

Interactive apps

We currently offer JupyterLab, RStudio Server, MATLAB, Mathematica, COMSOL, Visual Studio Code, and Stata access on both the Discovery and Endeavour clusters. Additionally, there is a terminal application intended for launching GUI applications from the command line.

To start an interactive session in OnDemand, select the application you want to use from the Interactive App dropdown menu at the top of the OnDemand dashboard. Alternatively, select one of the pinned or frequently-used apps on the home page of the dashboard.

Interactive-apps

Once you select an application, the session creation page appears.

App-creation

Customize your interactive session using the following form fields:

  • Cluster: Select either the general-use Discovery cluster or the Endeavour condo cluster. You must belong to a project with access to the Endeavour cluster in order to select this cluster; otherwise, you will receive an sbatch error (Invalid account or account/partition combination specified).
  • Version (MATLAB and RStudio only): Select from the available versions in the dropdown.

Version

  • Account: The project account to charge resources to. The dropdown should contain all projects you are a member of, and they will be of the form <PI_name>_<project_ID>.
  • Partition: The cluster partition to submit the job to. See the Discovery Resource Overview for more information on the different partitions on Discovery. Depending on the partition you choose, you may not see all of the form fields in this list.
  • Number of CPUs: Number of CPU cores to allocate for your session. The maximum number of cores available depends on the partition selected above.
  • Memory (GB): Amount of memory to allocate. If left blank, a default of 2 GB of memory per CPU core will be allocated.
  • GPU Type (optional): Type of GPU you wish to use. This field is optional and will only be displayed for partitions that have GPU resources. Available GPU types also depend on the partition selected above.
  • Number of GPUs (optional): Number of GPUs to allocate. Maximum of 2. This field is optional and will only be displayed for partitions that have GPU resources. When this field is left empty, Slurm defaults will be applied.
  • Number of hours: Amount of time to allocate to your session. Maximum number of hours varies depending on cluster and partition selected. When the time allocated runs out, your session will end.
  • Constraint: Node features to request (currently, CPU model).
  • BLAS library (COMSOL only): Select from the available libraries in the dropdown. Each library is optimized for a specific CPU architecture.

BLAS

If you would like to receive an email notification when your session starts, check the corresponding checkbox at the end of the form. Otherwise, click Launch to launch your session:

Jupyter

This will schedule your session in the Slurm queue. On the My Interactive Sessions page, your session will be highlighted in blue with a status of "Starting" or "Queued":

Jupyter

When your session is ready to use, you will see it highlighted in green with a status of "Running":

Jupyter

RStudio Server sessions include a username and password for you to use to log in to RStudio:

RStudio

MATLAB and Stata include sliders to set Compression and Image Quality:

Sliders

MATLAB, Mathematica, COMSOL, and Stata run on VNC software.

  • Compression refers to how much the app stream gets compressed. If you have a low-bandwidth network connection, you'll want to choose a higher compression level for a smoother experience. If you have a slow CPU in your computer, you'll want to choose a lower compression level.
  • Image Quality refers to the encoder settings used by VNC and will affect the visual quality of the app. Lower quality settings use less bandwidth, so adjust accordingly to your network connection.

Click Connect for Jupyter and RStudio Server or Launch for MATLAB and Stata to open your session in a new browser tab.

Managing your interactive sessions

You can view all of your OnDemand interactive sessions by selecting My Interactive Sessions in the main OnDemand menu. Each session will include the following information:

  • Host: Clicking the host will open a shell with access to the node that your session is running on.
  • Created at: The date and time the session was created.
  • Time Remaining: The time remaining for your session, based on the number of hours you specified when creating the session.
  • Session ID: Clicking the session ID will open the file directory for the session, which contains configuration files, logs, and scripts for your app session.
  • Username/Password (RStudio only): The credentials to use when logging in to RStudio Server.

If you no longer need an interactive session, cancel it using the red Cancel button. The Cancel button ends the interactive session, but leaves the session entry in the "My Interactive Sessions" page. This allows you to re-launch a session with the same settings you had before.

Cancel button

If you do not plan on re-launching the session, delete it using the red Delete button. This removes the session completely from the "My Interactive Sessions" page.

Getting help

CARC OnDemand gives user the option to submit a help ticket directly from the dashboard. Select the question mark button to reveal a drop-down menu. Then select "Submit Support Ticket."

Help ticket

Additional information

Back to top