-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathparser.c
More file actions
115 lines (102 loc) · 3.11 KB
/
parser.c
File metadata and controls
115 lines (102 loc) · 3.11 KB
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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
/* SPDX-License-Identifier: GPL-3.0-or-later */
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "netdata.h"
#include "callbacks.h"
#include "parser.h"
struct parser_statistics {
int conn_failed;
int scanner_success;
int scanner_failed;
int delivery_success;
int delivery_failed;
int unknown_success;
int unknown_failed;
int other;
};
static
void *
parser_data_init() {
struct parser_statistics * ret;
ret = calloc(1, sizeof * ret);
return ret;
}
static
void
parser_clear(struct parser_statistics * data) {
memset(data, 0, sizeof * data);
}
static
void
parser_process(const char * line, struct parser_statistics * data) {
const char * ptr;
if ((ptr = strstr(line, "Successfully updated table "))) {
if (strstr(ptr, "scanner")) {
data->scanner_success++;
}
else if (strstr(ptr, "delivery")) {
data->delivery_success++;
}
else {
data->unknown_success++;
}
} else if ((ptr = strstr(line, "Failed to update table "))) {
if (strstr(ptr, "scanner")) {
data->scanner_failed++;
}
else if (strstr(ptr, "delivery")) {
data->delivery_failed++;
}
else {
data->unknown_failed++;
}
} else if ((ptr = strstr(line, "Can't connect to MySQL server on "))) {
if (strstr(ptr, "[Errno 111] Connection refused")) {
data->conn_failed++;
}
} else {
data->other++;
}
}
static
int
parser_print_hdr(const char * name) {
nd_chart("parser", name, "table_updates", "", "Table updates by parser", "update", "parser", "parser.table_updates", ND_CHART_TYPE_STACKED);
nd_dimension("conn_failed", "conn_failed", ND_ALG_ABSOLUTE, 1, 1, ND_VISIBLE);
nd_dimension("scanner_success", "scanner_success", ND_ALG_ABSOLUTE, 1, 1, ND_VISIBLE);
nd_dimension("scanner_failed", "scanner_failed", ND_ALG_ABSOLUTE, 1, 1, ND_VISIBLE);
nd_dimension("delivery_success", "delivery_success", ND_ALG_ABSOLUTE, 1, 1, ND_VISIBLE);
nd_dimension("delivery_failed", "delivery_failed", ND_ALG_ABSOLUTE, 1, 1, ND_VISIBLE);
nd_dimension("unknown_success", "unknown_success", ND_ALG_ABSOLUTE, 1, 1, ND_VISIBLE);
nd_dimension("unknown_failed", "unknown_failed", ND_ALG_ABSOLUTE, 1, 1, ND_VISIBLE);
nd_dimension("other", "other", ND_ALG_ABSOLUTE, 1, 1, ND_VISIBLE);
return fflush(stdout);
}
static
int
parser_print(const char * name, const struct parser_statistics * data,
const unsigned long time) {
nd_begin_time("parser", name, "table_updates", time);
nd_set("conn_failed", data->conn_failed);
nd_set("scanner_success", data->scanner_success);
nd_set("scanner_failed", data->scanner_failed);
nd_set("delivery_success", data->delivery_success);
nd_set("delivery_failed", data->delivery_failed);
nd_set("unknown_success", data->unknown_success);
nd_set("unknown_failed", data->unknown_failed);
nd_set("other", data->other);
nd_end();
return fflush(stdout);
}
static
struct stat_func parser = {
.init = &parser_data_init,
.fini = &free,
.print_hdr = parser_print_hdr,
.print = (int (*)(const char *, const void *, unsigned long))parser_print,
.process = (void (*)(const char *, void *))parser_process,
.postprocess = NULL,
.clear = (void (*)(void *))&parser_clear,
};
struct stat_func * parser_func = &parser;