linux怎么查看本机内存大小
430
2022-10-09
#yyds干货盘点# Prometheus Exporter(二十三) Slurm Exporter
本文已经收录在 Prometheus 合集 Prometheus 都可以采集那些指标?-- 常用 Exporter 合集 中。
HPC 集群的监控中作业调度系统监控是必不可少的,今天我们来看看看使用 Slurm 作业调度系统以后如何监控。
监控 Slurm 作业调度系统可以使用 Slurm Exporter ,我推荐使用 ,最新版本 是 0.19.0,发布于 2021年 4 月 16 日 。
安装运行
Slurm Exporter 部署非常简单,下载最新的安装包,然后解压,将解压好的 prometheus-slurm-exporter 文件拷贝到 /usr/bin/prometheus-slurm-exporter 就完成了第一步,然后将下面的 SystemD 的启动文件 slurm-exporter.service 拷贝到指定目录就完成了。
[Unit] Description=Prometheus SLURM Exporter [Service] ExecStart=/usr/bin/prometheus-slurm-exporter Restart=always RestartSec=15 [Install] WantedBy=multi-user.target
启动 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 就可以。
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~