]> arthur.barton.de Git - netdata.git/blob - src/proc_loadavg.c
finer timing measurements on internal plugins = now each internal plugin has its...
[netdata.git] / src / proc_loadavg.c
1 #ifdef HAVE_CONFIG_H
2 #include <config.h>
3 #endif
4 #include <stdio.h>
5 #include <stdlib.h>
6 #include <string.h>
7
8 #include "log.h"
9 #include "common.h"
10 #include "appconfig.h"
11 #include "procfile.h"
12 #include "rrd.h"
13 #include "plugin_proc.h"
14
15 int do_proc_loadavg(int update_every, unsigned long long dt) {
16         static procfile *ff = NULL;
17         static int do_loadavg = -1, do_all_processes = -1;
18
19         if(dt) {};
20
21         if(!ff) {
22                 char filename[FILENAME_MAX + 1];
23                 snprintf(filename, FILENAME_MAX, "%s%s", global_host_prefix, "/proc/loadavg");
24                 ff = procfile_open(config_get("plugin:proc:/proc/loadavg", "filename to monitor", filename), " \t,:|/", PROCFILE_FLAG_DEFAULT);
25         }
26         if(!ff) return 1;
27
28         ff = procfile_readall(ff);
29         if(!ff) return 0; // we return 0, so that we will retry to open it next time
30
31         if(do_loadavg == -1)            do_loadavg                      = config_get_boolean("plugin:proc:/proc/loadavg", "enable load average", 1);
32         if(do_all_processes == -1)      do_all_processes        = config_get_boolean("plugin:proc:/proc/loadavg", "enable total processes", 1);
33
34         if(procfile_lines(ff) < 1) {
35                 error("/proc/loadavg has no lines.");
36                 return 1;
37         }
38         if(procfile_linewords(ff, 0) < 6) {
39                 error("/proc/loadavg has less than 6 words in it.");
40                 return 1;
41         }
42
43         double load1 = strtod(procfile_lineword(ff, 0, 0), NULL);
44         double load5 = strtod(procfile_lineword(ff, 0, 1), NULL);
45         double load15 = strtod(procfile_lineword(ff, 0, 2), NULL);
46
47         //unsigned long long running_processes  = strtoull(procfile_lineword(ff, 0, 3), NULL, 10);
48         unsigned long long active_processes             = strtoull(procfile_lineword(ff, 0, 4), NULL, 10);
49         //unsigned long long next_pid                           = strtoull(procfile_lineword(ff, 0, 5), NULL, 10);
50
51
52         RRDSET *st;
53
54         // --------------------------------------------------------------------
55
56         if(do_loadavg) {
57                 st = rrdset_find_byname("system.load");
58                 if(!st) {
59                         st = rrdset_create("system", "load", NULL, "load", NULL, "System Load Average", "load", 100, update_every, RRDSET_TYPE_LINE);
60
61                         rrddim_add(st, "load1", NULL, 1, 1000, RRDDIM_ABSOLUTE);
62                         rrddim_add(st, "load5", NULL, 1, 1000, RRDDIM_ABSOLUTE);
63                         rrddim_add(st, "load15", NULL, 1, 1000, RRDDIM_ABSOLUTE);
64                 }
65                 else rrdset_next(st);
66
67                 rrddim_set(st, "load1", load1 * 1000);
68                 rrddim_set(st, "load5", load5 * 1000);
69                 rrddim_set(st, "load15", load15 * 1000);
70                 rrdset_done(st);
71         }
72
73         // --------------------------------------------------------------------
74
75         if(do_all_processes) {
76                 st = rrdset_find_byname("system.active_processes");
77                 if(!st) {
78                         st = rrdset_create("system", "active_processes", NULL, "processes", NULL, "System Active Processes", "processes", 750, update_every, RRDSET_TYPE_LINE);
79
80                         rrddim_add(st, "active", NULL, 1, 1, RRDDIM_ABSOLUTE);
81                 }
82                 else rrdset_next(st);
83
84                 rrddim_set(st, "active", active_processes);
85                 rrdset_done(st);
86         }
87
88         return 0;
89 }