blob: 6c30400ed178098ebe579c1370548d67ef006e98 [file] [log] [blame]
.TH sshare "1" "Slurm Commands" "August 2022" "Slurm Commands"
.SH "NAME"
sshare \- Tool for listing the shares of associations to a cluster.
.SH "SYNOPSIS"
\fBsshare\fR [\fIOPTIONS\fR...]
.SH "DESCRIPTION"
\fBsshare\fR is used to view Slurm share information. This command is
only viable when running with the priority/multifactor plugin.
The sshare information is derived from a database with the interface
being provided by \fBslurmdbd\fR (Slurm Database daemon) which is
read in from the slurmctld and used to process the shares available
to a given association. sshare provides Slurm share information of
Account, User, Raw Shares, Normalized Shares, Raw Usage, Normalized
Usage, Effective Usage, the Fair\-share factor, the GrpTRESMins limit,
Partitions and accumulated currently running TRES\-minutes for each association.
.SH "OPTIONS"
.TP
\fB\-A\fR, \fB\-\-accounts\fR=<\fIaccount\fR>
Display information for specific accounts (comma separated list).
.IP
.TP
\fB\-a\fR, \fB\-\-all\fR
Display information for all users.
.IP
.TP
\fB\-M\fR, \fB\-\-clusters\fR=<\fIstring\fR>
Clusters to issue commands to.
Note that the \fBslurmdbd\fR must be up for this option to work properly, unless
running in a federation with \fBFederationParameters=fed_display\fR configured.
.IP
.TP
\fB\-o\fR, \fB\-\-format\fR=<\fIoutput_format\fR>
Comma separated list of fields (use
"\-\-helpformat" for a list of available fields).
.IP
.TP
\fB\-\-help\fR
Display a description of sshare options and commands.
.IP
.TP
\fB\-l\fR, \fB\-\-long\fR
Long listing \- includes the normalized usage information.
.IP
.TP
\f3\-\-json\fP, \f3\-\-json\fP=\fIlist\fR, \f3\-\-json\fP=<\fIdata_parser\fR>
Dump information as JSON using the default data_parser plugin or explicit
data_parser with parameters. Sorting and formatting arguments will be ignored.
.IP
.TP
\fB\-n\fR, \fB\-\-noheader\fR
No header will be added to the beginning of the output.
.IP
.TP
\fB\-p\fR, \fB\-\-parsable\fR
Output will be '|' delimited with a '|' at the end.
.IP
.TP
\fB\-P\fR, \fB\-\-parsable2\fR
Output will be '|' delimited without a '|' at the end.
.IP
.TP
\fB\-m\fR, \fB\-\-partition\fR
If there are association based partitions in the system
print their names.
.IP
.TP
\fB\-\-usage\fR
Display a description of sshare options and commands.
.IP
.TP
\fB\-u\fR, \fB\-\-users\fR=<\fIuser_list\fR>
Display information for specific users (comma separated list).
.IP
.TP
\fB\-U\fR, \fB\-\-Users\fR
If specified only the users information are printed, the parent
and ancestors are not displayed.
.IP
.TP
\fB\-v\fR, \fB\-\-verbose\fR
Display more information about the specified options.
.IP
.TP
\fB\-V\fR, \fB\-\-version\fR
Display the version number of sshare.
.IP
.TP
\f3\-\-yaml\fP, \f3\-\-yaml\fP=\fIlist\fR, \f3\-\-yaml\fP=<\fIdata_parser\fR>
Dump information as YAML using the default data_parser plugin or explicit
data_parser with parameters. Sorting and formatting arguments will be ignored.
.IP
.SH "SSHARE OUTPUT FIELDS"
.TP
\f3Account\fP
The Account.
.IP
.TP
\f3User\fP
The User.
.IP
.TP
\f3Raw Shares\fP
The raw shares assigned to the user or account.
.IP
.TP
\f3Norm Shares\fP
The shares assigned to the user or account normalized to the total
number of assigned shares.
.IP
.TP
\f3Raw Usage\fP
The number of tres\-seconds (cpu\-seconds if TRESBillingWeights is not defined)
of all the jobs charged to the account or user. This number will decay over
time when PriorityDecayHalfLife is defined.
.IP
.TP
\f3Norm Usage\fP (only appears with \fBsshare \-l\fR option)
The Raw Usage normalized to the total number of tres\-seconds of all
jobs run on the cluster, subject to the PriorityDecayHalfLife decay
when defined.
.IP
.TP
\f3Effectv Usage\fP
The Effective Usage augments the normalized usage to account for usage
from sibling accounts.
.IP
.TP
\f3FairShare\fP
The Fair\-Share factor, based on a user or account's assigned shares and
the effective usage charged to them or their accounts.
.IP
.TP
\f3GrpTRESMins\fP
The TRES\-minutes limit set on the account. The total number of cpu
minutes that can possibly be used by past, present and future jobs
running from this account and its children.
.IP
.TP
\f3GrpTRESRaw\fP
The raw TRES usage that has been used by jobs running from
this account and its children.
.IP
.TP
\f3TRESRunMins\fP
The number of TRES\-minutes allocated by jobs currently running against
the account. Used to limit the combined total number of TRES minutes
used by all jobs running with this account and its children.
This takes into consideration time limit of running jobs and consumes it,
if the limit is reached no new jobs are started until other jobs finish
to allow time to free up.
.IP
.SH "FAIR_TREE MODIFICATIONS"
When PriorityFlags=FAIR_TREE is set (the default, unless NO_FAIR_TREE is set),
calculations are done differently.
As a result, the following fields are added or modified:
.TP
\f3Norm Shares\fP
The shares assigned to the user or account normalized to the total
number of assigned shares within the level.
.IP
.TP
\f3Effectv Usage\fP
Effectv Usage is the association's usage normalized with its parent.
.IP
.TP
\f3Level FS\fP (only appears with \fBsshare \-l\fR option)
This is the association's fairshare value compared to its siblings, calculated
as Norm Shares / Effectv Usage. If an association is over\-served, the value is
between 0 and 1. If an association is under\-served, the value is greater than 1.
Associations with no usage receive the highest possible value, infinity.
.IP
.LP
More information about Fair Tree can be found in doc/html/fair_tree.html or
at https://slurm.schedmd.com/fair_tree.html
.SH "PERFORMANCE"
.PP
Executing \fBsshare\fR sends a remote procedure call to \fBslurmctld\fR. If
enough calls from \fBsshare\fR or other Slurm client commands that send remote
procedure calls to the \fBslurmctld\fR daemon come in at once, it can result in
a degradation of performance of the \fBslurmctld\fR daemon, possibly resulting
in a denial of service.
.PP
Do not run \fBsshare\fR or other Slurm client commands that send remote
procedure calls to \fBslurmctld\fR from loops in shell scripts or other
programs. Ensure that programs limit calls to \fBsshare\fR to the minimum
necessary for the information you are trying to gather.
.SH "ENVIRONMENT VARIABLES"
.PP
Some \fBsshare\fR options may be set via environment variables. These
environment variables, along with their corresponding options, are listed below.
(Note: Command line options will always override these settings.)
.TP 20
\fBSLURM_CONF\fR
The location of the Slurm configuration file.
.IP
.TP
\fBSLURM_DEBUG_FLAGS\fR
Specify debug flags for sshare to use. See DebugFlags in the
\fBslurm.conf\fR(5) man page for a full list of flags. The environment
variable takes precedence over the setting in the slurm.conf.
.IP
.TP
\fBSLURM_JSON\fR
Control JSON serialization:
.IP
.RS
.TP
\fBcompact\fR
Output JSON as compact as possible.
.IP
.TP
\fBpretty\fR
Output JSON in pretty format to make it more readable.
.IP
.RE
.TP
\fBSLURM_YAML\fR
Control YAML serialization:
.IP
.RS
.TP
\fBcompact\fR Output YAML as compact as possible.
.IP
.TP
\fBpretty\fR Output YAML in pretty format to make it more readable.
.RE
.IP
.SH "EXAMPLES"
.TP
Display information about users in a particular account:
.IP
.nf
$ sshare \-A <Account>
.fi
.TP
Display information about a specific user in a parsable format:
.IP
.nf
$ sshare \-\-parsable \-\-users=<User>
.fi
.SH "COPYING"
Copyright (C) 2008 Lawrence Livermore National Security.
Produced at Lawrence Livermore National Laboratory (cf, DISCLAIMER).
.br
Copyright (C) 2010\-2022 SchedMD LLC.
.LP
This file is part of Slurm, a resource management program.
For details, see <https://slurm.schedmd.com/>.
.LP
Slurm is free software; you can redistribute it and/or modify it under
the terms of the GNU General Public License as published by the Free
Software Foundation; either version 2 of the License, or (at your option)
any later version.
.LP
Slurm is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
details.
.SH "SEE ALSO"
\fBslurm.conf\fR(5),
\fBslurmdbd\fR(8)