Prometheus Exporter (二十三)Slurm Exporter
本文已经收录在 Prometheus 合集 Prometheus 都可以采集那些指标?-- 常用 Exporter 合集 中。
HPC 集群的监控中作业调度系统监控是必不可少的,今天我们来看看看使用 Slurm 作业调度系统以后如何监控。
监控 Slurm 作业调度系统可以使用 Slurm Exporter ,我推荐使用 https://github.com/vpenso/prometheus-slurm-exporter ,最新版本 是 0.19.0,发布于 2021 年 4 月 16 日 。
安装运行
Slurm Exporter 部署非常简单,下载最新的安装包,然后解压,将解压好的 prometheus-slurm-exporter
文件拷贝到 /usr/bin/prometheus-slurm-exporter
就完成了第一步,然后将下面的 SystemD 的启动文件 slurm-exporter.service 拷贝到指定目录就完成了。
启动 Slurm Exporter 使用 systemctl start slurm-exporter
命令就可以了。
可以收集的监控指标
使用 Slurm Exporter 可以收集很多的指标,包括 CPU、GPU、机器节点、提交的作业、作业分区的状态、每个账户和用户的作业信息、调度器的信息,我们大概看一下具体是什么。
CPU 的状态
Allocated: 已经被分配给作业的 CPU 数量。
Idle: 没有被分配给做而已,空闲的 CPU 数量。
Other: 暂时无法使用的 CPU 数量,不能使用的原因有多种,可能是机器坏了,也可能是被管理员设置了这些机器不能用于作业分配,一般是处于维护或者特殊用途
Total: CPU 总数
GPU 的状态
Allocated: 已经被分配给作业的 GPU 数量。
Other: GPUs which are unavailable for use at the moment.
Total: GPU 卡的总数.
Utilization: 集群中总的 GPU 使用率.
从 0.19 版本开始,GPU 计费必须在命令行中添加 -gpu-acct
选项来显式启用,否则它将不会被激活。
机器节点的状态
Allocated: 已经被分配给作业的节点。
Completing: 与这些节点关联的所有作业都在完成过程中。a
Down: 不能使用的节点.
Drain: 处于这个状态的节点有 2 中不同的状态,
drained 状态的节点(被系统管理员都标记为不可用)
处于 drained 状态的节点(当前正在执行作业,但不会分配给新的作业)。
Fail: 这些节点预计很快就会失败,并且无法响应系统管理员的请求,也无法使用它们。
Error: 当前处于错误状态且不能运行任何作业的节点
Idle: 未分配给任何作业的节点,因此可供使用。
Maint: 当前被标记为维护标志的节点。
Mixed: 这些节点已经分配了一些 cpu,而其他 cpu 处于空闲状态。
Resv: 这些节点处于高级预订状态,通常不可用。
从 0.18 版本开始,Slurm 也提取并导出了每个已知节点的以下信息:
CPU:分配的 cpu 个数、空闲 cpu 个数、其他 cpu 个数和总数。
内存:已分配和总内存。
标签:主机名及其 Slurm 状态(例如空闲、混合、分配、耗尽等)
作业状态
PENDING: 等待分配资源的作业.
PENDING_DEPENDENCY: 由于未执行的作业依赖关系而等待的作业。
RUNNING: 目前的已经分配资源并且正在执行的作业。
SUSPENDED: 作业有分配,但执行已经被暂停,cpu 已经被释放给其他作业。
CANCELLED: 被用户或系统管理员明确取消的作业。
COMPLETING: 正在完成的作业
COMPLETED: 作业运行完成,终止了所有节点上的所有进程,退出码为 0。
CONFIGURING: 作业已经分配了资源,但正在等待它们准备好使用。
FAILED: 作业以非零退出码或其他失败条件终止。
TIMEOUT: 作业在达到限制的时间后就终止了。
PREEMPTED: 由于抢占而终止作业。
NODE_FAIL: 由于一个或多个分配的节点失败而终止作业。
作业分区的状态
每个分区运行/挂起的作业,分配给 Slurm 帐户和用户。
每个分区的总/分配/空闲 CPU 加上每个用户 ID 的已用 CPU。
每个账户和用户的作业信息
Running/Pending/Suspended 每个账号的作业.
Running/Pending/Suspended 每个用户的作业
调度器的信息
Server Thread count: 当前活动的 slurmctld 线程数。
Queue size: scheduler queue 的长度
DBD Agent queue size: SlurmDBD 的消息队列的长度。
Last cycle: 上一个调度周期的时间(以微秒为单位)。
Mean cycle:自上次重置以来调度周期的平均值。
Cycles per minute: 每分钟调度执行的计数器。
(Backfill) Last cycle: 最后一次回填周期的时间(以微秒计)。
(Backfill) Mean cycle: 自上次重置以来,以微秒计的平均回填调度周期。
(Backfill) Depth mean: 自上次重置以来的回填调度周期中已处理作业的平均值。
(Backfill) Total Backfilled Jobs (since last slurm start): 自从上次 Slurm 启动以来,大量的作业得以恢复。
(Backfill) Total Backfilled Jobs (since last stats cycle start): 自上次统计复位以来,由于回填而启动的作业数量。
(Backfill) Total backfilled heterogeneous Job components: 自上次 Slurm 启动以来,由于回填,异构作业组件的数量开始增加。
小结
这基本是 HPC 集群监控的最后一个组件了。使用 Node Exporter、Infiniband Exporter、Lustre Exporter、Slurm Exporter 这个组合已经能够基本完成 HPC 集群的监控,如果是使用 PBS 作业调度系统可以使用 PBS Exporter 替换 Slurm,使用其他并行文件存储用相对应的 Exporter 替换 Lustre Exporter 就可以。
版权声明: 本文为 InfoQ 作者【耳东@Erdong】的原创文章。
原文链接:【http://xie.infoq.cn/article/5d68849c42e4f1588d5f65be2】。未经作者许可,禁止转载。
评论