-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathslurm_sched_stats_diamond.py
79 lines (68 loc) · 3.38 KB
/
slurm_sched_stats_diamond.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
#!/usr/bin/python
"""
slurm_sched_stats_diamond.py
A script that uses Popen to get the slurm scheduler statistics.
"""
import sys,os,json
import shlex,subprocess
import diamond.collector
class SlurmSchedStatsCollector(diamond.collector.Collector):
def get_default_config(self):
"""
Returns the default collector settings
"""
config = super(SlurmSchedStatsCollector, self).get_default_config()
config.update({
'path': 'sdiag'
})
return config
def collect(self):
try:
proc = subprocess.Popen('sdiag', stdout=subprocess.PIPE, universal_newlines=True)
except:
return
else:
# Construct dictionary of stats
sd = dict()
pl = ""
for line in proc.stdout:
if "Remote" in line:
break
elif "Main" in line:
pl = "m"
elif "Backfilling" in line:
pl = "b"
elif ":" in line:
line = line.replace(" ","").replace('\t',"").replace("(","").replace(")","")
line = pl + line
sd.update(dict(s.split(":", 1) for s in shlex.split(line) if ':' in s))
# Slurmctld Stats
self.publish('server_thread_count',sd['Serverthreadcount'])
self.publish('agent_queue_size',sd['Agentqueuesize'])
# Jobs Stats
self.publish('jobs_submitted',sd['Jobssubmitted'])
self.publish('jobs_started',sd['Jobsstarted'])
self.publish('jobs_completed',sd['Jobscompleted'])
self.publish('jobs_canceled',sd['Jobscanceled'])
self.publish('jobs_failed',sd['Jobsfailed'])
# Main Scheduler Stats
self.publish('main_last_cycle',sd['mLastcycle'])
self.publish('main_max_cycle',sd['mMaxcycle'])
self.publish('main_total_cycles',sd['mTotalcycles'])
self.publish('main_mean_cycle',sd['mMeancycle'])
self.publish('main_mean_depth_cycle',sd['mMeandepthcycle'])
self.publish('main_cycles_per_minute',sd['mCyclesperminute'])
self.publish('main_last_queue_length',sd['mLastqueuelength'])
# Backfilling stats
self.publish('bf_total_jobs_since_slurm_start',sd['bTotalbackfilledjobssincelastslurmstart'])
self.publish('bf_total_jobs_since_cycle_start',sd['bTotalbackfilledjobssincelaststatscyclestart'])
self.publish('bf_total_cycles',sd['bTotalcycles'])
self.publish('bf_last_cycle',sd['bLastcycle'])
self.publish('bf_max_cycle',sd['bMaxcycle'])
self.publish('bf_queue_length',sd['bLastqueuelength'])
self.publish('bf_mean_cycle', (sd['bMeancycle'] if sd.has_key('bMeancycle') else 0))
self.publish('bf_depth_mean', (sd['bDepthMean'] if sd.has_key('bDepthMean') else 0))
self.publish('bf_depth_mean_try', (sd['bDepthMeantrydepth'] if sd.has_key('bDepthMeantrydepth') else 0))
self.publish('bf_queue_length_mean', (sd['bQueuelengthmean'] if sd.has_key('bQueuelengthmean') else 0))
self.publish('bf_last_depth_cycle',sd['bLastdepthcycle'])
self.publish('bf_last_depth_cycle_try',sd['bLastdepthcycletrysched'])