This repository has been archived by the owner on Nov 26, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 330
/
dstat_disk_svctm.py
76 lines (67 loc) · 2.43 KB
/
dstat_disk_svctm.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
### Author: David Nicklay <david-d$nicklay,com>
### Modified from disk-util: Dag Wieers <dag$wieers,com>
class dstat_plugin(dstat):
"""
The average service time (in milliseconds) for I/O requests that were
issued to the device.
Warning! Do not trust this field any more.
"""
def __init__(self):
self.version = 2
self.nick = ('svctm',)
self.type = 'f'
self.width = 4
self.scale = 1
self.diskfilter = re.compile('^([hsv]d[a-z]+\d+|cciss/c\d+d\d+p\d+|dm-\d+|md\d+|mmcblk\d+p\d0|VxVM\d+)$')
self.open('/proc/diskstats')
self.cols = 1
self.struct = dict( nr_ios=0, tot_ticks=0 )
def discover(self, *objlist):
ret = []
for l in self.splitlines():
if len(l) < 13: continue
if l[3:] == ['0',] * 11: continue
name = l[2]
ret.append(name)
for item in objlist: ret.append(item)
if not ret:
raise Exception('No suitable block devices found to monitor')
return ret
def vars(self):
ret = []
if op.disklist:
varlist = op.disklist
else:
varlist = []
blockdevices = [os.path.basename(filename) for filename in glob.glob('/sys/block/*')]
for name in self.discover:
if self.diskfilter.match(name): continue
if name not in blockdevices: continue
varlist.append(name)
varlist.sort()
for name in varlist:
if name in self.discover:
ret.append(name)
return ret
def name(self):
return self.vars
def extract(self):
for l in self.splitlines():
if len(l) < 13: continue
if l[3:] == ['0',] * 11: continue
if l[3] == '0' and l[7] == '0': continue
name = l[2]
if name not in self.vars or name == 'total': continue
self.set2[name] = dict(
nr_ios = int(l[3])+int(l[7]),
tot_ticks = int(l[12]),
)
for name in self.vars:
tput = ( self.set2[name]['nr_ios'] - self.set1[name]['nr_ios'] )
if tput:
util = ( self.set2[name]['tot_ticks'] - self.set1[name]['tot_ticks'] )
self.val[name] = ( util * 1.0 / tput, )
else:
self.val[name] = ( 0.0, )
if step == op.delay:
self.set1.update(self.set2)