load, traffic plugins: Changed license to GPLv2 only.
[collectd.git] / src / load.c
1 /**
2  * collectd - src/load.c
3  * Copyright (C) 2005,2006  Florian octo Forster
4  *
5  * This program is free software; you can redistribute it and/or modify it
6  * under the terms of the GNU General Public License as published by the
7  * Free Software Foundation; only version 2 of the License is applicable.
8  *
9  * This program is distributed in the hope that it will be useful, but
10  * WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12  * General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License along
15  * with this program; if not, write to the Free Software Foundation, Inc.,
16  * 51 Franklin St, Fifth Floor, Boston, MA  02110-1301 USA
17  *
18  * Authors:
19  *   Florian octo Forster <octo at verplant.org>
20  **/
21
22 #include "collectd.h"
23 #include "common.h"
24 #include "plugin.h"
25
26 #define MODULE_NAME "load"
27
28 #if defined(HAVE_GETLOADAVG) || defined(KERNEL_LINUX) || defined(HAVE_LIBSTATGRAB)
29 # define LOAD_HAVE_READ 1
30 #else
31 # define LOAD_HAVE_READ 0
32 #endif
33
34 #ifdef HAVE_SYS_LOADAVG_H
35 #include <sys/loadavg.h>
36 #endif
37
38 #ifdef HAVE_GETLOADAVG
39 #if !defined(LOADAVG_1MIN) || !defined(LOADAVG_5MIN) || !defined(LOADAVG_15MIN)
40 #define LOADAVG_1MIN  0
41 #define LOADAVG_5MIN  1
42 #define LOADAVG_15MIN 2
43 #endif
44 #endif /* defined(HAVE_GETLOADAVG) */
45
46 static data_source_t dsrc[3] =
47 {
48         {"shortterm", DS_TYPE_GAUGE, 0.0, 100.0},
49         {"midterm",   DS_TYPE_GAUGE, 0.0, 100.0},
50         {"longterm",  DS_TYPE_GAUGE, 0.0, 100.0}
51 };
52
53 static data_set_t ds =
54 {
55         "load", 3, dsrc
56 };
57
58 #if LOAD_HAVE_READ
59 static void load_submit (double snum, double mnum, double lnum)
60 {
61         value_t values[3];
62         value_list_t vl = VALUE_LIST_INIT;
63
64         values[0].gauge = snum;
65         values[1].gauge = mnum;
66         values[2].gauge = lnum;
67
68         vl.values = values;
69         vl.values_len = 3;
70         vl.time = time (NULL);
71         strcpy (vl.host, hostname);
72         strcpy (vl.plugin, "load");
73         strcpy (vl.plugin_instance, "");
74         strcpy (vl.type_instance, "");
75
76         plugin_dispatch_values ("load", &vl);
77 }
78
79 static int load_read (void)
80 {
81 #if defined(HAVE_GETLOADAVG)
82         double load[3];
83
84         if (getloadavg (load, 3) == 3)
85                 load_submit (load[LOADAVG_1MIN], load[LOADAVG_5MIN], load[LOADAVG_15MIN]);
86         else
87                 syslog (LOG_WARNING, "load: getloadavg failed: %s", strerror (errno));
88 /* #endif HAVE_GETLOADAVG */
89
90 #elif defined(KERNEL_LINUX)
91         double snum, mnum, lnum;
92         FILE *loadavg;
93         char buffer[16];
94
95         char *fields[8];
96         int numfields;
97         
98         if ((loadavg = fopen ("/proc/loadavg", "r")) == NULL)
99         {
100                 syslog (LOG_WARNING, "load: fopen: %s", strerror (errno));
101                 return;
102         }
103
104         if (fgets (buffer, 16, loadavg) == NULL)
105         {
106                 syslog (LOG_WARNING, "load: fgets: %s", strerror (errno));
107                 fclose (loadavg);
108                 return;
109         }
110
111         if (fclose (loadavg))
112                 syslog (LOG_WARNING, "load: fclose: %s", strerror (errno));
113
114         numfields = strsplit (buffer, fields, 8);
115
116         if (numfields < 3)
117                 return;
118
119         snum = atof (fields[0]);
120         mnum = atof (fields[1]);
121         lnum = atof (fields[2]);
122
123         load_submit (snum, mnum, lnum);
124 /* #endif KERNEL_LINUX */
125
126 #elif defined(HAVE_LIBSTATGRAB)
127         double snum, mnum, lnum;
128         sg_load_stats *ls;
129
130         if ((ls = sg_get_load_stats ()) == NULL)
131                 return;
132
133         snum = ls->min1;
134         mnum = ls->min5;
135         lnum = ls->min15;
136
137         load_submit (snum, mnum, lnum);
138 #endif /* HAVE_LIBSTATGRAB */
139
140         return (0);
141 }
142 #endif /* LOAD_HAVE_READ */
143
144 void module_register (void)
145 {
146         plugin_register_data_set (&ds);
147 #if LOAD_HAVE_READ
148         plugin_register_read ("load", load_read);
149 #endif
150 }
151
152 #undef MODULE_NAME