Skip to content

Collection of utilities / helper scripts to make life easier on our HPC clusters.

License

Notifications You must be signed in to change notification settings

pneerincx/cluster-utils

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

cluster-utils

Collection of utilities / helper scripts to make life easier on our HPC clusters.

master branch CI status

CircleCI

1. List of tools.

AAI tools.

Tools to get reports on authentication & authorization settings and identities.

  • caccounts: Lists details of Slurm cluster accounts.
  • cfinger: Lists details of a specific user's system/# account.
  • colleagues: Lists group owners, data managers and other regular group members.

Tools for monitoring cluster/job status

  • ctop: Top-like overview of cluster status and resource usage.
  • cps: List all processes on a machine in a tree-like hierarchy.
  • sjeff: Lists Slurm Job EFFiciency for jobs.
  • cnodes: Lists state of compute nodes.
  • cqos: Lists details for all Quality of Service levels.
  • cqueue: Lists running and queued jobs.
  • cprio: Lists priority of all jobs in the queue.
  • cshare: Lists the shares Slurm users in Slurm accounts have, their recent resource usage and how this impacts their fair share.
  • hpc-environment-slurm-report: Creates reports on cluster usage as percentage of available resources for specified period (e.g. week, month, etc.).

Tools for monitoring file system and quota status

Wrapper for Slurm's sacctmgr command with custom output format to list which users are associated to which slurm accounts on which clusters. Example output:

   Cluster Account              User             Share Def QOS   QOS
---------- -------------------- ------------ --------- --------- -----------------------------------
  calculon root                                      1 priority  [list of QoS account had access to]
  calculon  root                root                 1 priority  [list of QoS account had access to]
  calculon  users                                    1 regular   [list of QoS account had access to]
  calculon   users              [1st_user]           1 regular   [list of QoS account had access to]
  calculon   users              [2nd_user]           1 regular   [list of QoS account had access to]
etc.

cfinger is finger on steroids: basic account details which you would also get from standard finger supplemented with public keys associated to accounts and group memberships.

Example output:

===========================================================
Basic account details for [account]:
-----------------------------------------------------------
User            : [account]
UID             : [0-9]+
Home            : /home/[account]
Shell           : /bin/bash
Mail            : Real Name <r.name@fully.qualified.domain>
-----------------------------------------------------------
User [account] is authorized for access to groups:
-----------------------------------------------------------
Primary group   : [account]  ([0-9]+)
Secondary group : [group]    ([0-9]+)
-----------------------------------------------------------
Public key(s) for authenticating user [account]:
-----------------------------------------------------------
ssh-rsa AAAAB3NzaC1yc....QR+zbmsAX0Mpw== [account]
===========================================================

Lists all users of all groups a user is a member of. Optionally you can specify:

  • -g [group_name] to list only members of the specified group.
  • -g all to list members of all groups.
  • -e to sort group members by expiration date of their account. User accounts are expanded to Real Names and email addresses.

Example output:

==============================================================================================================
Colleagues in the [group] group:                                                                       
==============================================================================================================
[group] owner(s):                                                                             
--------------------------------------------------------------------------------------------------------------
[account]       YYYY-MM-DD        Real Name <r.name@fully.qualified.domain>
==============================================================================================================
[group] datamanager(s):                                                                       
--------------------------------------------------------------------------------------------------------------
[account]       YYYY-MM-DD        Real Name <r.name@fully.qualified.domain>
==============================================================================================================
[group] member(s):                                                                            
--------------------------------------------------------------------------------------------------------------
[account]       YYYY-MM-DD        Real Name <r.name@fully.qualified.domain>
==============================================================================================================

Cluster-top or ctop for short provides an integrated real-time overview of resource availability and usage. The example output below is in black and white, but you'll get a colorful picture if your terminal supports ANSI colors. Press the ? key to get online help, which will explain how to filter, sort and color results as well as how to search for specific users, jobs, nodes, quality of service (QoS) levels, etc.

Usage Totals: 288/504 Cores | 7/11 Nodes | 69/7124 Jobs Running                                                             2016-12-01-T12:22:56
Node States: 3 IDLE | 1 IDLE+DRAIN | 7 MIXED

   cluster         node 1 2 3 4 5 6 7 8 9 0   1 2 3 4 5 6 7 8 9 0   1 2 3 4 5 6 7 8 9 0   1 2 3 4 5 6 7 8 9 0   1 2 3 4 5 6 7 8   load
                        -------------------------------------------------------------------------------------------------------
  calculon     calculon . . . . . . . . . .   . . @ @ @ @ @ @ @ @   @ @ @ @                                                       2.08 = Ok
                        -------------------------------------------------------------------------------------------------------
  calculon umcg-node011 E i T d Z O U d O w   w w w S S S S e e e   e . . . . . . . . .   . . . . . . . . . .   . . . . . . @ @  10.96 = too low!
                        -------------------------------------------------------------------------------------------------------
  calculon umcg-node012 0 0 0 0 0 0 0 0 0 0   0 0 0 0 0 0 0 0 0 0   0 0 0 0 0 0 0 0 0 0   0 0 0 0 0 0 0 0 0 0   0 0 0 0 0 0 0 0   0.57 = Ok
                        -------------------------------------------------------------------------------------------------------
  calculon umcg-node013 < N N N N C C C C =   = = = x x x x b b b   b D D D D A A A A I   I I I T T T T Y Y Y   Y . . . . . @ @  17.31 = too low!
                        -------------------------------------------------------------------------------------------------------
  calculon umcg-node014 B B B B B B B B B B   B B B B B B B B B B   B B B B B L c k k k   k - - - - E E E E S   S S S . . . @ @  30.40 = too low!
                        -------------------------------------------------------------------------------------------------------
  calculon umcg-node015 u I I I I I I I I I   I I I I I I I I I I   I I I I I I e v D o   B B B B N N N N i i   i i K K K K @ @  34.71 = too low!
                        -------------------------------------------------------------------------------------------------------
  calculon umcg-node016 H Z Y Y Y Y Y Y Y Y   Y Y Y Y Y Y Y Y Y Y   Y Y Y Y Y Y Y U + _   > > > > a a a a n n   n n k k k k @ @  34.39 = too low!
                        -------------------------------------------------------------------------------------------------------
  calculon umcg-node017 L L L L L L L L L L   L L L L L L L L L L   L L L L L p p p p H   H H H b b b b | | |   | / / / / . @ @  22.02 = too low!
                        -------------------------------------------------------------------------------------------------------
  calculon umcg-node018 s z ~ V y c c c c c   c c c c c c c c c c   c c c c c c c c c c   V q l a C C C C K K   K K A A A A @ @  38.03 = too low!
                        -------------------------------------------------------------------------------------------------------
  calculon umcg-node019 . . . . . . . . . .   . . . . . . . . . .   . . . . . . . . . .   . . . . . . . . . .   . . . . . . @ @   0.51 = Ok
                        -------------------------------------------------------------------------------------------------------
  calculon umcg-node020 . . . . . . . . . .   . . . . . . . . . .   . . . . . . . . . .   . . . . . . . . . .   . . . . . . @ @   0.59 = Ok
                        -------------------------------------------------------------------------------------------------------
                        legend: ? unknown | @ busy | X down | . idle | 0 offline | ! other

      JobID  Username     QoS             Jobname                                  S  CPU(%) CPU(%) Mem(GiB) Mem(GiB)   Walltime   Walltime
                                                                                       ~used   req.     used     req.       used  requested
  u = 562757 [account]    regular-long    VCF_filter_convert_concat_tt.sh          R      15    100     34.3    120.0 0-14:09:10 3-00:00:00
  E = 579935 [account]    regular-long    SRA_download_fastq_round2.sh             R       0    100      2.1    120.0 3-02:19:50 5-00:00:00
  s = 580724 [account]    regular-long    RELF10_%j                                R      99    100      1.2     20.0 0-21:13:23 2-00:00:00
  z = 580725 [account]    regular-long    RELF11_%j                                R      99    100      1.2     20.0 0-21:13:23 2-00:00:00
  ~ = 580726 [account]    regular-long    RELF12_%j                                R      99    100      1.2     20.0 0-21:13:23 2-00:00:00
  V = 580727 [account]    regular-long    RELF13_%j                                R      99    100      1.2     20.0 0-21:13:23 2-00:00:00
  y = 580728 [account]    regular-long    RELF14_%j                                R      99    100      1.2     20.0 0-21:13:23 2-00:00:00
  H = 580729 [account]    regular-long    RELF15_%j                                R      99    100      1.2     20.0 0-21:13:23 2-00:00:00
  Z = 580730 [account]    regular-long    RELF16_%j                                R      99    100      1.2     20.0 0-21:13:23 2-00:00:00
  i = 580731 [account]    regular-long    RELF17_%j                                R      99    100      1.2     20.0 0-17:30:31 2-00:00:00
  T = 580732 [account]    regular-long    RELF18_%j                                R      99    100      1.2     20.0 0-17:30:31 2-00:00:00
  d = 581023 [account]    regular-long    move_check_downloaded_files.sh           R       1    100      0.0     40.0 0-21:13:23 3-00:00:00
  c = 606872 [account]    regular-short   kallisto33                               R    2311   2500     22.3     40.0 0-01:19:23 0-05:59:00
  I = 606873 [account]    regular-short   kallisto34                               R    2291   2500     22.3     40.0 0-01:17:23 0-05:59:00
  Y = 606874 [account]    regular-short   kallisto35                               R    1719   2500     23.7     40.0 0-00:24:32 0-05:59:00
  B = 606876 [account]    regular-short   kallisto37                               R    1685   2500     22.3     40.0 0-00:23:01 0-05:59:00
  L = 606877 [account]    regular-short   kallisto38                               R    1165   2500     22.3     40.0 0-00:13:33 0-05:59:00

A wrapper for the regular ps command to change the default output/formatting. Lists all processes on a machine in a tree-like hierarchy and how much time, the percentage of CPU and the percentage of memory each process consumes. Example output:

USER          PID    PPID     ELAPSED %CPU %MEM CMD
demo-user     20112     1    03:45:10  0.0  0.0 SCREEN -S tool_test
demo-user     20113 20112    03:45:10  0.0  0.0  \_ /bin/bash
demo-user     26873 20113       14:01  0.0  0.0      \_ bash test_fastq.sh
demo-user     26893 26873       14:01  0.0  0.0          \_ /bin/bash /groups/umcg-gcc/tmp01/demo-user/tool/tool.sh --workflow fastq --config /groups/umcg-gcc/tmp01/demo-user/tool/test/output/fastq_nanopore/custom.cfg
demo-user     26910 26893       14:01  0.0  0.0              \_ /bin/bash /groups/umcg-gcc/tmp01/demo-user/tool/tool.sh --workflow fastq --config /groups/umcg-gcc/tmp01/demo-user/tool/test/output/fastq_nanopore/custom.cfg
demo-user     26911 26910       14:01  8.6  0.6                  \_ /usr/bin/java --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.io=ALL-UNNAMED
demo-user      3248 26911       10:45  0.0  0.0                      \_ /bin/bash -ue .command.run
demo-user      3305  3248       10:45  0.0  0.0                      |   \_ tee .command.out
demo-user      3306  3248       10:45  0.0  0.0                      |   \_ tee .command.err
demo-user      3307  3248       10:45  0.0  0.0                      |   \_ /bin/bash -ue .command.run
demo-user      3308  3307       10:45  0.0  0.0                      |       \_ /bin/bash /groups/umcg-gcc/tmp01/demo-user/tool/test/output/fastq_nanopore/.nxf.work/19/3e5f75e/.command.run nxf_trace
demo-user      3379  3308       10:45  0.0  0.0                      |           \_ /bin/bash /groups/umcg-gcc/tmp01/demo-user/tool/test/output/fastq_nanopore/.nxf.work/19/3e5f75e/.command.sh
demo-user      9750  3379       10:15  0.0  0.0                      |           |   \_ Apptainer runtime parent
demo-user      9772  9750       10:15  1.1  0.0                      |           |       \_ /usr/bin/python3 /usr/local/bin/sniffles --input tool_tool_fam0_HG002_sliced.cram
demo-user      9816  9772       10:12  0.0  0.0                      |           |           \_ /usr/bin/python3 /usr/local/bin/sniffles --input tool_tool_fam0_HG002_sliced.cram
demo-user      9817  9772       10:12  0.0  0.0                      |           |           \_ /usr/bin/python3 /usr/local/bin/sniffles --input tool_tool_fam0_HG002_sliced.cram
demo-user      9818  9772       10:12  0.3  0.0                      |           |           \_ /usr/bin/python3 /usr/local/bin/sniffles --input tool_tool_fam0_HG002_sliced.cram
demo-user      9819  9772       10:12  0.3  0.0                      |           |           \_ /usr/bin/python3 /usr/local/bin/sniffles --input tool_tool_fam0_HG002_sliced.cram
demo-user      3382  3308       10:45  0.8  0.0                      |           \_ /bin/bash /groups/umcg-gcc/tmp01/demo-user/tool/test/output/fastq_nanopore/.nxf.work/19/3e5f75e/.command.run nxf_trace
demo-user      3696 26911       00:41  0.0  0.0                      \_ /bin/bash -ue .command.run
demo-user      3719  3696       00:41  0.0  0.0                          \_ tee .command.out
demo-user      3720  3696       00:41  0.0  0.0                          \_ tee .command.err
demo-user      3721  3696       00:41  0.0  0.0                          \_ /bin/bash -ue .command.run
demo-user      3722  3721       00:41  0.0  0.0                              \_ /bin/bash /groups/umcg-gcc/tmp01/demo-user/tool/test/output/fastq_nanopore/.nxf.work/51/c0ea14b/.command.run nxf_trace
demo-user      3740  3722       00:41  0.0  0.0                                  \_ /bin/bash /groups/umcg-gcc/tmp01/demo-user/tool/test/output/fastq_nanopore/.nxf.work/51/c0ea14b/.command.sh
demo-user      6022  3740       00:32  0.2  0.0                                  |   \_ Apptainer runtime parent
demo-user      6040  6022       00:32  0.2  0.0                                  |       \_ bash /opt/bin/run_clair3.sh --bam_fn=tool_tool_fam0_HG002.cram.bam --ref_fn=/groups/umcg-gcc/rsc01/tool/resources/GRCh38/GCA_000001405.15_GRCh38_no_alt_analysis_set.fna
demo-user      6098  6040       00:32  0.0  0.0                                  |           \_ bash /opt/bin/run_clair3.sh --bam_fn=tool_tool_fam0_HG002.cram.bam --ref_fn=/groups/umcg-gcc/rsc01/tool/resources/GRCh38/GCA_000001405.15_GRCh38_no_alt_analysis_set.fna
demo-user      6100  6098       00:32  0.0  0.0                                  |           |   \_ bash /opt/bin/run_clair3.sh --bam_fn=tool_tool_fam0_HG002.cram.bam --ref_fn=/groups/umcg-gcc/rsc01/tool/resources/GRCh38/GCA_000001405.15_GRCh38_no_alt_analysis_set.fna
demo-user      6106  6100       00:32  0.0  0.0                                  |           |       \_ /bin/bash /opt/bin/scripts/clair3_c_impl.sh --bam_fn /groups/umcg-gcc/tmp01/demo-user/tool/test/output/fastq_nanopore/.nxf.work/51/c0ea14b/tool_tool_fam0_HG002.cram
demo-user      7009  6106       00:30  0.7  0.0                                  |           |           \_ perl /opt/conda/envs/clair3/bin/parallel --retries 4 -C --joblog /groups/umcg-gcc/tmp01/demo-user/tool/test/output/fastq_nanopore/.nxf.work/51/c0ea14b/log/
demo-user     15204  7009       00:07 87.4  0.1                                  |           |           |   \_ python3 /opt/bin/scripts/../clair3.py CallVariantsFromCffi --chkpnt_fn /opt/models/r941_prom_sup_g5014/pileup
demo-user     16536  7009       00:03 69.3  0.0                                  |           |           |   \_ python3 /opt/bin/scripts/../clair3.py CallVariantsFromCffi --chkpnt_fn /opt/models/r941_prom_sup_g5014/pileup
demo-user     16814  7009       00:01 79.0  0.0                                  |           |           |   \_ python3 /opt/bin/scripts/../clair3.py CallVariantsFromCffi --chkpnt_fn /opt/models/r941_prom_sup_g5014/pileup
demo-user      7015  6106       00:30  0.0  0.0                                  |           |           \_ tee /groups/umcg-gcc/tmp01/demo-user/tool/test/output/fastq_nanopore/.nxf.work/51/c0ea14b/log/1_call_var_bam_pileup.log
demo-user      6099  6040       00:32  0.0  0.0                                  |           \_ tee /groups/umcg-gcc/tmp01/demo-user/tool/test/output/fastq_nanopore/.nxf.work/51/c0ea14b/run_clair3.log
demo-user      3742  3722       00:41  1.7  0.0                                  \_ /bin/bash /groups/umcg-gcc/tmp01/demo-user/tool/test/output/fastq_nanopore/.nxf.work/51/c0ea14b/.command.run nxf_trace

Slurm Job EFFiciency or sjeff for short provides an overview of finished jobs, the resources they requested and how efficient these were used. The job efficiency is a percentage and defined as: used resources / requested resources * 100. Note that for CPU core usage the average is reported whereas for Memory usage the max peak usage is reported. The example output below is in black and white, but you'll get a colorful picture if your terminal supports ANSI colors:

  • green: Ok.
  • yellow: you requested too much and wasted resources.
  • red: you requested too little and your jobs ran inefficiently or got killed or were close to getting killed.
================================================================================================================
JobName                                       | Time                 | Cores (used=average) | Memory (used=peak)
                                              |   Requested  Used(%) |   Requested  Used(%) | Requested  Used(%)
----------------------------------------------------------------------------------------------------------------
validateConvading_s01_PrepareFastQ_0          |    07:00:00     0.05 |           4     0.00 |       8Gn     0.01
validateConvading_s01_PrepareFastQ_1          |    07:00:00     0.06 |           4     0.00 |       8Gn     0.01
validateConvading_s03_FastQC_0                |    05:59:00     0.39 |           1    60.00 |       2Gn    11.81
validateConvading_s03_FastQC_1                |    05:59:00     0.40 |           1    66.28 |       2Gn    11.31
validateConvading_s04_BwaAlignAndSortSam_0    |    23:59:00     0.31 |           8    39.18 |      30Gn    29.96
validateConvading_s04_BwaAlignAndSortSam_1    |    23:59:00     0.35 |           8    45.72 |      30Gn    30.17
validateConvading_s05_MergeBam_0              |    05:59:00     0.03 |          10     0.00 |      10Gn     0.00
validateConvading_s05_MergeBam_1              |    05:59:00     0.05 |          10     0.00 |      10Gn     0.00
validateConvading_s06_BaseRecalibrator_0      |    23:59:00     0.65 |           8   179.61 |      10Gn    49.54
validateConvading_s06_BaseRecalibrator_1      |    23:59:00     0.62 |           8   222.78 |      10Gn    53.23
validateConvading_s07_MarkDuplicates_0        |    16:00:00     0.13 |           5   193.42 |      30Gn     2.81
validateConvading_s07_MarkDuplicates_1        |    16:00:00     0.15 |           5   167.04 |      30Gn     2.72
validateConvading_s08_Flagstat_0              |    03:00:00     0.07 |           5     0.00 |      30Gn     0.00
validateConvading_s08_Flagstat_1              |    03:00:00     0.06 |           5     0.00 |      30Gn     0.00
validateConvading_s09a_Manta_0                |    16:00:00     0.01 |          21     0.00 |      30Gn     0.00
validateConvading_s09a_Manta_1                |    16:00:00     0.01 |          21     0.00 |      30Gn     0.00
validateConvading_s09b_Convading_0            |    05:59:00     1.29 |           1     1.79 |       4Gn     0.67
validateConvading_s09b_Convading_1            |    05:59:00     1.50 |           1     0.31 |       4Gn     0.70
================================================================================================================

Wrapper for Slurm's sinfo command with custom output format to list all compute nodes and their state. Example output:

PARTITION    AVAIL  NODES  STATE  S:C:T   CPUS  MAX_CPUS_PER_NODE  MEMORY  TMP_DISK  FEATURES                      GROUPS  TIMELIMIT   JOB_SIZE  ALLOCNODES  NODELIST            REASON
duo-pro*     up     8      mixed  8:6:1   48    46                 258299  1063742   umcg,ll,tmp02,tmp04           all     7-00:01:00  1         all         umcg-node[011-018]  none
duo-dev      up     1      mixed  8:6:1   48    46                 258299  1063742   umcg,ll,tmp02,tmp04           all     7-00:01:00  1         all         umcg-node019        none
duo-dev      up     1      idle   8:6:1   48    46                 258299  1063742   umcg,ll,tmp02,tmp04           all     7-00:01:00  1         all         umcg-node020        none
duo-ds-umcg  up     1      idle   2:12:1  24    12                 387557  1063742   umcg,tmp02,tmp04,prm02,prm03  all     7-00:01:00  1         all         calculon            none
duo-ds-ll    up     1      idle   2:1:1   2     2                  7872    0         ll,tmp04,prm02,prm03          all     7-00:01:00  1         all         lifelines           none

Wrapper for Slurm's sacctmgr command with custom output format to list all Quality of Service (QoS) levels and their limits. Example output:

QOSLevelName       Priority  UsageFactor  MaxResources                     MaxSubmit    MaxResources                     MaxSubmit  MaxWalltime  CanPreemptJobsInQOSlevel
                                          PerQOSLevel                      PerQOSLevel  PerUser                          PerUser    PerJob       
normal             0         1.000000                                                                                                            
leftover           0         0.000000     cpu=0,gres/gpu=0,mem=0           30000                                         10000                   
leftover-short     0         0.000000                                      30000                                         10000      06:00:00     
leftover-medium    0         0.000000                                      30000                                         10000      1-00:00:00   
leftover-long      0         0.000000                                      3000                                          1000       7-00:00:00   
regular            10        1.000000     cpu=0,gres/gpu=0,mem=0           30000                                         5000                    
regular-short      10        1.000000                                      30000                                         5000       06:00:00     leftover-long,leftover-medium,leftover-short
regular-medium     10        1.000000     cpu=139,gres/gpu=13,mem=535660M  30000        cpu=104,gres/gpu=10,mem=401745M  5000       1-00:00:00   leftover-long,leftover-medium,leftover-short
regular-long       10        1.000000     cpu=87,gres/gpu=8,mem=334788M    3000         cpu=69,gres/gpu=7,mem=267830M    1000       7-00:00:00   leftover-long,leftover-medium,leftover-short
priority           20        2.000000     cpu=0,gres/gpu=0,mem=0           5000                                          1000                    
priority-short     20        2.000000                                      5000         cpu=52,gres/gpu=5,mem=200872M    1000       06:00:00     leftover-long,leftover-medium,leftover-short
priority-medium    20        2.000000     cpu=104,gres/gpu=10,mem=401745M  2500         cpu=34,gres/gpu=4,mem=133915M    500        1-00:00:00   leftover-long,leftover-medium,leftover-short
priority-long      20        2.000000     cpu=52,gres/gpu=5,mem=200872M    250          cpu=34,gres/gpu=4,mem=133915M    50         7-00:00:00   leftover-long,leftover-medium,leftover-short
interactive        30        1.000000     cpu=0,gres/gpu=0,mem=0                                                         1                       
interactive-short  30        1.000000                                                   cpu=15,gres/gpu=4,mem=46869M     1          06:00:00     leftover-long,leftover-medium,leftover-short,regular-short
ds                 10        1.000000     cpu=0,gres/gpu=0,mem=0           5000                                          1000                    
ds-short           10        1.000000                                      5000         cpu=4,gres/gpu=0,mem=4G          1000       06:00:00     
ds-medium          10        1.000000     cpu=2,gres/gpu=0,mem=2G          2500         cpu=2,gres/gpu=0,mem=2G          500        1-00:00:00   
ds-long            10        1.000000     cpu=1,gres/gpu=0,mem=1G          250          cpu=1,gres/gpu=0,mem=1G          50         7-00:00:00   

Wrapper for Slurm's squeue command with custom output format to list running and scheduled jobs. Example output:

JOBID    PARTITION  QOS             NAME                             USER           ST  TIME   NODELIST(REASON)  START_TIME           PRIORITY
4864542  duo-pro    regular-medium  run_GS1_FinalReport_small_chr3   [user]         PD  0:00   (Priority)        2018-06-30T02:16:05  0.00011811894367
4864541  duo-pro    regular-medium  run_GS1_FinalReport_small_chr2   [user]         PD  0:00   (Priority)        2018-06-30T01:47:42  0.00011811894367
4864540  duo-pro    regular-medium  run_GS1_FinalReport_small_chr22  [user]         PD  0:00   (Priority)        2018-06-30T01:34:43  0.00011811894367
4864539  duo-pro    regular-medium  run_GS1_FinalReport_small_chr21  [user]         PD  0:00   (Resources)       2018-06-29T21:55:46  0.00011811894367
4864537  duo-pro    regular-medium  run_GS1_FinalReport_small_chr1   [user]         R   10:09  umcg-node015      2018-06-29T16:03:44  0.00011821347292
4864526  duo-pro    regular-medium  run_GS1_FinalReport_small_chr0   [user]         R   10:13  umcg-node013      2018-06-29T16:03:40  0.00011821347292
4864527  duo-pro    regular-medium  run_GS1_FinalReport_small_chr10  [user]         R   10:13  umcg-node011      2018-06-29T16:03:40  0.00011821347292
4864528  duo-pro    regular-medium  run_GS1_FinalReport_small_chr11  [user]         R   10:13  umcg-node017      2018-06-29T16:03:40  0.00011821347292

Wrapper for Slurm's sprio command with custom output format to list components that make up the priority of scheduled jobs. Example output:

#####   ####     ABSOLUTE  NORMALIZED        ABS   NORM       ABSOLUTE   NORMALIZED  ABS     NORM       ####
JOBID   USER     PRIORITY  PRIORITY          AGE   AGE        FAIRSHARE  FAIRSHARE   QOS     QOS        NICE
417928  userA    543307    0.00012649867973  1000  1.0000000  42308      0.4230769   500000  0.5000000  0
421373  userB    503197    0.00011715986820  1000  1.0000000  2198       0.0219780   500000  0.5000000  0
421374  userB    503197    0.00011715986820  1000  1.0000000  2198       0.0219780   500000  0.5000000  0
421375  userB    503197    0.00011715986820  1000  1.0000000  2198       0.0219780   500000  0.5000000  0
499136  userC    506621    0.00011795710702  29    0.0285103  6593       0.0659341   500000  0.5000000  0
499137  userC    506621    0.00011795710567  29    0.0285045  6593       0.0659341   500000  0.5000000  0
499138  userC    506621    0.00011795710413  28    0.0284979  6593       0.0659341   500000  0.5000000  0
499139  userC    506621    0.00011795710278  28    0.0284921  6593       0.0659341   500000  0.5000000  0

Wrapper for Slurm's sshare command with custom output format to list the raw share(s) assigned to users, their recent usage and their resulting fair share. Example output:

SlurmAccount    SlurmUser    RawShares  NormalizedShares  RawUsage   NormalizedUsage  EffectiveUsage  FairShare  LevelFS            TRESRunMins
============    =========    =========  ================  ========   ===============  ==============  =========  =======            ===========
root                                    0.000000          113872206                   0.000000                                      cpu=137703,mem=3204775596,energy=0,node=31091,billing=519855,fs/disk=0,vmem=0,pages=0
 root           root         1          0.500000          0          0.000000         0.000000        1.000000   inf                cpu=0,mem=0,energy=0,node=0,billing=0,fs/disk=0,vmem=0,pages=0
 users                       1          0.500000          113872206  1.000000         1.000000                   0.500000           cpu=137703,mem=3204775596,energy=0,node=31091,billing=519855,fs/disk=0,vmem=0,pages=0
  group1                     parent     0.500000          53110578   0.466405         0.466405                                      cpu=19363,mem=820313361,energy=0,node=13129,billing=118725,fs/disk=0,vmem=0,pages=0
   group1       userA        1          0.005587          0          0.000000         0.000000        0.417582   69872977.459919    cpu=0,mem=0,energy=0,node=0,billing=0,fs/disk=0,vmem=0,pages=0
   group1       userB        1          0.005587          938998     0.008246         0.008246        0.115385   0.677485           cpu=0,mem=0,energy=0,node=0,billing=0,fs/disk=0,vmem=0,pages=0
   group1       userC        1          0.005587          345425     0.003033         0.003033        0.142857   1.841664           cpu=0,mem=0,energy=0,node=0,billing=0,fs/disk=0,vmem=0,pages=0
  group2                     parent     0.500000          6921258    0.060781         0.060781                                      cpu=0,mem=0,energy=0,node=0,billing=0,fs/disk=0,vmem=0,pages=0
   group2       userD        1          0.005587          0          0.000000         0.000000        0.994505   inf                cpu=0,mem=0,energy=0,node=0,billing=0,fs/disk=0,vmem=0,pages=0
   group2       userE        1          0.005587          6921258    0.060781         0.060781        0.032967   0.091914           cpu=0,mem=0,energy=0,node=0,billing=0,fs/disk=0,vmem=0,pages=0

Custom SLURM cluster reporting tool. Lists available resources and resource usage over a specified period of time. Example output:

======================================================================
Cluster usage report from 2016-09-01T00:00:00 to 2016-10-01T00:00:00.
----------------------------------------------------------------------
Available resources for calculon cluster:
   Partition   CPUs (cores)   Memory (GB)
----------------------------------------------------------------------
   duo-pro              368          1840
   duo-dev               92           460
   duo-ds                12           128
   TOTAL                472          2428
----------------------------------------------------------------------
Cluster   Account        Login  CPU used  MEM used
----------------------------------------------------------------------
calculon    users    [account]    27.61%    25.90%
calculon    users    [account]    17.31%    11.27%
calculon    users    [account]     6.44%     3.54%
calculon    users    [account]     5.71%     5.60%
calculon    users    [account]     3.53%     1.06%
TOTAL         ANY          ALL    60.60%    47.40%
======================================================================

Custom quota reporting tool for users. Lists quota for all groups a user is a member of. Example output:

====================================================================================================================================================
                             |                     Total size of files and folders |                   Total number of files and folders |
(T) Path/Filesystem          |       used       quota       limit            grace |       used       quota       limit            grace |    Status
----------------------------------------------------------------------------------------------------------------------------------------------------
(P) /home/[account]          |    748.5 M       1.0 G       2.0 G             none |     27.0 k       0.0         0.0               none |        Ok
----------------------------------------------------------------------------------------------------------------------------------------------------
(G) /apps                    |    738.3 G       1.0 T       2.0 T             none |  1,137.0 k       0.0         0.0               none |        Ok
(G) /.envsync/tmp04          |    691.8 G       5.0 T       8.0 T             none |    584.0 k       0.0         0.0               none |        Ok
----------------------------------------------------------------------------------------------------------------------------------------------------
(G) /groups/[group]/prm02    |     11.8 T      12.0 T      15.0 T             none |     26.0 k       0.0         0.0               none |        Ok
(G) /groups/[group]/tmp04    |     52.4 T      50.0 T      55.0 T      5d12h17m16s |  4,101.0 k       0.0         0.0               none | EXCEEDED!
(F) /groups/[group]/tmp02    |     25.0 T      40.0 T      40.0 T             none |    169.0 k       0.0         0.0               none |        Ok
====================================================================================================================================================

Custom quota reporting tool for admins. Lists quota for all groups on a Physical File System (PFS). Output is similar to that from the quota tool listed above.

2. How to use this repo and contribute.

We use a standard GitHub workflow except that we use only one branch "master" as this is a relatively small repo and we don't need the additional overhead from branches.

   ⎛¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯⎞                                               ⎛¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯⎞
   ⎜ Shared repo a.k.a. "blessed"         ⎜ <<< 7: Merge <<< pull request <<< 6: Send <<< ⎜ Your personal online fork a.k.a. "origin"          ⎜
   ⎜ github.com/molgenis/cluster-utils.git⎜ >>> 1: Fork blessed repo >>>>>>>>>>>>>>>>>>>> ⎜ github.com/<your_github_account>/cluster-utils.git ⎜
   ⎝______________________________________⎠                                               ⎝____________________________________________________⎠
      v                                                                                                   v      ʌ
      v                                                                       2: Clone origin to local disk      5: Push commits to origin
      v                                                                                                   v      ʌ
      v                                                                                  ⎛¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯⎞
      `>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> 3: pull from blessed >>> ⎜ Your personal local clone                          ⎜
                                                                                         ⎜ ~/git/cluster-utils                                ⎜
                                                                                         ⎝____________________________________________________⎠
                                                                                              v                                        ʌ
                                                                                              `>>> 4: Commit changes to local clone >>>´
  1. Fork this repo on GitHub (Once).
  2. Clone to your local computer and setup remotes (Once).
#
# Clone repo
#
git clone https://github.com/your_github_account/cluster-utils.git
#
# Add blessed remote (the source of the source) and prevent direct push.
#
cd cluster-utils
git remote add            blessed https://github.com/molgenis/cluster-utils.git
git remote set-url --push blessed push.disabled
  1. Pull from "blessed" (Regularly from 3 onwards).
#
# Pull from blessed master.
#
cd cluster-utils
git pull blessed master

Make changes: edit, add, delete...

  1. Commit changes to local clone.
#
# Commit changes.
#
git status
git add some/changed/files
git commit -m 'Describe your changes in a commit message.'
  1. Push commits to "origin".
#
# Push commits.
#
git push origin master
  1. Go to your fork on GitHub and create a pull request.

  2. Have one of the other team members review and eventually merge your pull request.

  3. Back to 3 to pull from "blessed" to get your local clone in sync.

#
# Pull from blessed master.
#
cd cluster-utils
git pull blessed master

etc.

About

Collection of utilities / helper scripts to make life easier on our HPC clusters.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Perl 52.6%
  • Shell 47.4%