mirror of
https://github.com/munin-monitoring/contrib.git
synced 2018-11-08 00:59:34 +01:00
bb7bf0bcd7
Added common functions autoconf_check_readable and fail. Added some TODOs for later completion. Updated messages from upstream plugins.
47 lines
1.5 KiB
C
47 lines
1.5 KiB
C
#include <string.h>
|
|
#include <stdio.h>
|
|
#include <unistd.h>
|
|
#include "common.h"
|
|
|
|
int interrupts(int argc, char **argv) {
|
|
FILE *f;
|
|
char buff[256];
|
|
if(argc > 1) {
|
|
if(!strcmp(argv[1], "config")) {
|
|
puts("graph_title Interrupts and context switches\n"
|
|
"graph_args --base 1000 -l 0\n"
|
|
"graph_vlabel interrupts & ctx switches / ${graph_period}\n"
|
|
"graph_category system\n"
|
|
"graph_info This graph shows the number of interrupts and context switches on the system. These are typically high on a busy system.\n"
|
|
"intr.info Interrupts are events that alter sequence of instructions executed by a processor. They can come from either hardware (exceptions, NMI, IRQ) or software.");
|
|
puts("ctx.info A context switch occurs when a multitasking operatings system suspends the currently running process, and starts executing another.\n"
|
|
"intr.label interrupts\n"
|
|
"ctx.label context switches\n"
|
|
"intr.type DERIVE\n"
|
|
"ctx.type DERIVE\n"
|
|
"intr.max 100000\n"
|
|
"ctx.max 100000\n"
|
|
"intr.min 0\n"
|
|
"ctx.min 0");
|
|
print_warncrit("intr");
|
|
print_warncrit("ctx");
|
|
return 0;
|
|
}
|
|
if(!strcmp(argv[1], "autoconf"))
|
|
return autoconf_check_readable(PROC_STAT);
|
|
}
|
|
if(!(f=fopen(PROC_STAT, "r")))
|
|
return fail("cannot open " PROC_STAT);
|
|
while(fgets(buff, 256, f)) {
|
|
if(!strncmp(buff, "intr ", 5)) {
|
|
buff[5 + strcspn(buff + 5, " \t\n")] = '\0';
|
|
printf("intr.value %s\n", buff+5);
|
|
} else if(!strncmp(buff, "ctxt ", 5)) {
|
|
buff[5 + strcspn(buff + 5, " \t\n")] = '\0';
|
|
printf("ctx.value %s\n", buff+5);
|
|
}
|
|
}
|
|
fclose(f);
|
|
return 0;
|
|
}
|