Resource Monitoring

The Hyak clusters make use of the Slurm scheduler to submit and run jobs. The scheduler provides a rich set of commands (e.g., sacct, sinfo) to query the state of the cluster but the extensive options can be daunting to navigate. We'll provide some useful example calls below in addition to some information about our custom resource monitoring program called hyakalloc.

squeue#

squeue is used to monitor the Slurm queue. By default, squeue displays a list of all jobs running on Hyak. To monitor the status of a specific user's jobs, use squeue -u UWNetID, replacing UWNetID with the UW Net ID of the user of interest. To view the queue for a specific account, use squeue -A accountname.

squeue -A stf
JOBID PARTITION NAME USER ST TIME NODES NODELIST(REASON)
23314234 compute SR_H_1 UWNetID PD 0:00 1 (Priority)
23314235 compute SR_H_2 UWNetID PD 0:00 1 (Priority)
23314236 compute SR_H_3 UWNetID PD 0:00 1 (Priority)
23314237 compute SR_H_4 UWNetID PD 0:00 1 (Priority)
23313236 compute interact UWNetID PD 0:00 1 (Priority)
23350637 compute interact UWNetID R 54:22 1 n3263

sacct#

sacct displays accounting data for all jobs and job steps in the Slurm job accounting log or Slurm database.

See all running jobs#

The -a flag implies all users, you can switch it out with -u netID for specific users. You can also modify the output fields by adjusting the -o flag.

sacct -s running -a -X -o user,jobid,elapsed,alloccpus,reqmem,nnodes,account,partition,node,reqtres%30

See all pending jobs#

The -a flag implies all users, you can switch it out with -u netID for specific users. You can also modify the output fields by adjusting the -o flag.

sacct -s pending -a -X -o user,jobid,elapsed,alloccpus,reqmem,nnodes,account,partition,node,reqtres%30

sinfo#

sinfo allows you to view information about Slurm nodes and partitions.

GPUs#

Summary of all the GPUs on the cluster and their current state. You can adjust the output fields (i.e., -O) for resources of interest (e.g., /tmp space on a node).

sinfo -p ckpt -O nodehost,cpusstate,freemem,gres,gresused -S nodehost | grep -v null

hyakalloc#

While you can use built-in Slurm commands query the resources used and what is available, the Hyak team has provided a useful utility called hyakalloc. This program will make those queries on your behalf and present it in a user friendly format.

Default#

If you run hyakalloc without any arguments it will display all the account and partition combinations you have access to, where you can submit jobs that will start right away and have no interruptions.

  • You can see the resource: your limits, what is currently in use, and what is available.
  • At the bottom you can also see the overall checkpoint (or ckpt) partition where you can access idle resources from other groups from across the cluster.
  • The output concludes with a notice about when the next cluster maintenance is. This is important to remember when submitting jobs to specify a job runtime that will end before the next maintenance.
$ hyakalloc
Account resources available to user: npho
โ•ญโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ•ฎ
โ”‚ Account โ”‚ Partition โ”‚ CPUs โ”‚ Memory โ”‚ GPUs โ”‚ โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚ uwit โ”‚ compute โ”‚ 1304 โ”‚ 6071G โ”‚ 0 โ”‚ TOTAL โ”‚
โ”‚ โ”‚ โ”‚ 0 โ”‚ 0G โ”‚ 0 โ”‚ USED โ”‚
โ”‚ โ”‚ โ”‚ 1304 โ”‚ 6071G โ”‚ 0 โ”‚ FREE โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚ uwit โ”‚ bigmem โ”‚ 40 โ”‚ 374G โ”‚ 0 โ”‚ TOTAL โ”‚
โ”‚ โ”‚ โ”‚ 0 โ”‚ 0G โ”‚ 0 โ”‚ USED โ”‚
โ”‚ โ”‚ โ”‚ 40 โ”‚ 374G โ”‚ 0 โ”‚ FREE โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚ uwit โ”‚ gpu-rtx6k โ”‚ 70 โ”‚ 652G โ”‚ 14 โ”‚ TOTAL โ”‚
โ”‚ โ”‚ โ”‚ 0 โ”‚ 0G โ”‚ 0 โ”‚ USED โ”‚
โ”‚ โ”‚ โ”‚ 70 โ”‚ 652G โ”‚ 14 โ”‚ FREE โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚ uwit โ”‚ hugemem โ”‚ 280 โ”‚ 5264G โ”‚ 0 โ”‚ TOTAL โ”‚
โ”‚ โ”‚ โ”‚ 0 โ”‚ 0G โ”‚ 0 โ”‚ USED โ”‚
โ”‚ โ”‚ โ”‚ 280 โ”‚ 5264G โ”‚ 0 โ”‚ FREE โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚ uwit โ”‚ interactive โ”‚ 40 โ”‚ 185G โ”‚ 0 โ”‚ TOTAL โ”‚
โ”‚ โ”‚ โ”‚ 0 โ”‚ 0G โ”‚ 0 โ”‚ USED โ”‚
โ”‚ โ”‚ โ”‚ 40 โ”‚ 185G โ”‚ 0 โ”‚ FREE โ”‚
โ•ฐโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ•ฏ
Checkpoint Resources
โ•ญโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ•ฎ
โ”‚ โ”‚ CPUs โ”‚ GPUs โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚ Idle: โ”‚ 160 โ”‚ 24 โ”‚
โ•ฐโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ•ฏ
Notice: Klone will be down for maintenance starting at 09:00AM Tuesday, Oct 12.
Subscribe to the hyak-users mailing list for more details.
$

Options#

The hyakalloc program has a rich set of command line arguments for more complex queries. For example, perhaps you want to know what another user's resource access and limits are (i.e., -u netID). You may be interested in auditing what your group's limits are (i.e., -g GROUP). Some queries may be too verbose so you can filter down to specific partitions with the -p flag.

$ hyakalloc -h
usage: hyakalloc [-h] [-a | -c | -u USER | -g GROUP] [-p PARTITION]
Queries Hyak allocation for users or groups.
optional arguments:
-h, --help show this help message and exit
-a, --all (Optional) Query all accounts & partitions.
-c, --ckpt (Optional) Query available resources in checkpoint.
-u USER, --user USER (Optional) Query a specific user.
-g GROUP, --group GROUP
(Optional) Query a specific group (Hyak Account).
-p PARTITION, --partition PARTITION
(Optional) Filter by partition name.
$