Slurmmon is meant to run on a RHEL/CentOS/SL 6 based system (e.g. 6.4). You'll of course need Slurm, and you'll also need a Ganglia installation and an Apache webserver running mod_python.
Several slurmmon components, such as submitting probe jobs and gathering allocation utilization numbers (a.k.a. whitespace reports), are optional.
The daemons run as a user named slurmmon
.
If you'll be running probe jobs, this user must be able to submit jobs to all the partitions being probed.
Since it should be a cluster account, the rpms do not make this user -- you have to.
Additionally, since slurmmon doesn't want the probe jobs to suffer hits to fairshare due to the constant job turnover, it increases the priority of each job, and that currently requires sudo. Thus, if you'll be running probe jobs, add something like this in your sudo configuration:
slurmmon HOSTNAME=(slurm) NOPASSWD: /usr/bin/scontrol update JobId\=* Priority\=*
where HOSTNAME
is the node where you're running the main slurmmon daemon (see below).
(Note that the *
in the above could match multiple words, it's not perfect.)
If you're not running probe jobs, you don't need the sudo config.
Identify a host on which to run the main slurmmon daemon that queries Slurm -- the one that collects sdiag
data, job counts, and other overall information.
This host should be in Ganglia (gmetric
needs to work), and, if you'll be running probe jobs, it must a host where the slurmmon
user can run sudo to change job priorities.
Install:
Configure it by editing /etc/slurmmon.conf
.
Specifically, set probejob_partitions
to be the set of partitions to which you want to send probe jobs. (Or set it to be empty to not use this feature.)
The default is particular to FASRC.
If you'll be generating whitespace reports, set web_root
to the location shared with the web server.
Start the service:
service slurmmond start
and chkconfig
it on:
chkconfig slurmmond on
If you want to monitor job allocation utilization and generate the whitespace reports of cluster efficiency, each compute node needs to run slurmmon daemons, too.
They are provided by the same rpm package, but the service is named differently and no configuration is currently needed.
The only requirement is that gmetric
must work on them.
On each compute node:
Install:
Start the service:
service slurmmond-computenode start
and chkconfig
it on:
chkconfig slurmmond-computenode on
Identify a host running ganglia-web
, and a graph.d
directory into which to put the slurmmon custom reports.
By default the rpm will use /var/www/ganglia/graph.d
, but this is an available Relocation in the rpm.
Install slurmmon-ganglia-0.0.2-fasrc03.noarch.rpm, possibly using --prefix
to put the files in a custom location.
Identify a host running httpd
and mod_python
.
If you'll be generating whitespace reports, also identify a web_root
on a shared filesystem that your webserver can read and to which the slurmmon_whitespace_report
cron job can write.
(See below about setting up this cron job -- usually it'll be on the same host as the main slurmmond service.)
Install:
using --relocate
to change /var/www/html/slurmmon
to your chosen web_root
.
(The default is fine if you're not generating whitespace reports.)
Configure it by editing /etc/slurmmon.conf
.
Specifically, set web_root
to whatever you used above and set ploturl_gmetaurl
, ploturl_cluster
, and ploturl_host
to what's needed to construct a url to reach the Ganglia plots.
If you're generating whitespace reports, you may consider editing /etc/httpd/conf.d/slurmmon.conf
and putting the url slurmmon/whitespace
behind an auth wall, since it does call out specific users about "poor" jobs and report job details.
Reload the web server config:
service httpd reload
You should now see plots at http://HOSTNAME/slurmmon/
where HOSTNAME
is this host.
There is a script named slurmmon_whitespace_report
that comes with the slurmmon-daemon
package.
On the host running the main slurmmond
service (and assuming it has a /etc/slurmmon.conf
specifying a proper web_root
), add a cron job similar to the following:
00 8 * * * /usr/sbin/slurmmon_whitespace_report
The latest report will then always be available at http://HOSTNAME/slurmmon/whitespace/
where HOSTNAME
is the web host above.