aboutsummaryrefslogtreecommitdiffstats
path: root/src/plugins/loadavg.py
blob: 68764294a78a80be3a5e249dabc1ddd0f68eb3a2 (plain) (blame)
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
# -*- python -*-
'''
xpybar – xmobar replacement written in python
Copyright © 2014, 2015, 2016, 2017, 2018, 2019  Mattias Andrée (maandree@kth.se)

This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program.  If not, see <http://www.gnu.org/licenses/>.
'''


class AverageLoad:
    '''
    The current average load, number of scheduling entities and latest PID
    
    @variable  total_avg_5_min:float     The average load over the last 5 minutes, sum of processors
    @variable  total_avg_10_min:float    The average load over the last 10 minutes, sum of processors
    @variable  total_avg_15_min:float    The average load over the last 15 minutes, sum of processors
    @variable  average_avg_5_min:float   The average load over the last 5 minutes, average of processors
    @variable  average_avg_10_min:float  The average load over the last 10 minutes, average of processors
    @variable  average_avg_15_min:float  The average load over the last 15 minutes, average of processors
    @variable  active_tasks:int          The number of active scheduling entities
    @variable  total_tasks:int           The total number of scheduling entities
    @variable  last_pid:int              The PID of the last created process on the system
    '''
    
    cpu_count = None
    '''
    :int?  The number of processors on the machine
    '''
    
    
    def __init__(self):
        '''
        Constructor
        '''
        uptime = None
        with open('/proc/loadavg', 'rb') as file:
            uptime = file.read()
        uptime = uptime.decode('utf-8', 'replace')
        uptime = uptime.replace('\n', ' ').split(' ')
        
        if AverageLoad.cpu_count is None:
            with open('/proc/cpuinfo', 'rb') as file:
                AverageLoad.cpu_count = file.read()
            AverageLoad.cpu_count = AverageLoad.cpu_count.decode('utf-8', 'replace').split('\n')
            AverageLoad.cpu_count = filter(lambda line : 'processor' in line, AverageLoad.cpu_count)
            AverageLoad.cpu_count = len(list(AverageLoad.cpu_count))
        
        self.total_avg_5_min, self.total_avg_10_min, self.total_avg_15_min, tasks, self.last_pid = uptime[:5]
        self.total_avg_5_min = float(self.total_avg_5_min)
        self.total_avg_10_min = float(self.total_avg_10_min)
        self.total_avg_15_min = float(self.total_avg_15_min)
        self.average_avg_5_min = self.total_avg_5_min / AverageLoad.cpu_count
        self.average_avg_10_min = self.total_avg_10_min / AverageLoad.cpu_count
        self.average_avg_15_min = self.total_avg_15_min / AverageLoad.cpu_count
        self.last_pid = int(self.last_pid)
        self.active_tasks, self.total_tasks = [int(t) for t in tasks.split('/')]