diff options
author | Pim van den Berg | 2012-09-07 13:48:21 +0200 |
---|---|---|
committer | Pim van den Berg | 2012-09-07 14:09:34 +0200 |
commit | e3f1cc22b6f392ba808034ef58e3b7946e3f0ba8 (patch) | |
tree | dd7c34e42c0a25b0e2ca47c55a3e3cf9c58875b3 /inc/collectd.inc.php | |
parent | plugin/snmp: add support for if_octets (diff) | |
download | apt-panopticon_cgp-e3f1cc22b6f392ba808034ef58e3b7946e3f0ba8.zip apt-panopticon_cgp-e3f1cc22b6f392ba808034ef58e3b7946e3f0ba8.tar.gz apt-panopticon_cgp-e3f1cc22b6f392ba808034ef58e3b7946e3f0ba8.tar.bz2 apt-panopticon_cgp-e3f1cc22b6f392ba808034ef58e3b7946e3f0ba8.tar.xz |
add support for varnish plugin categories
Since commit collectd-4.10.0-88-g02e12db the varnish plugin groups collected
values in categories. The collectd filestructure used for varnish is now:
<plugin>-<category>-<plugin_instance>/<type>-<type_instance>
Because this isn't distinguishable from a regular plugin like df, ...
df-var-tmp/df_complex-free.rrd ("var" isn't the category here)
... the category is only set with the varnish plugin.
Reported-by: Jonathan Huot <jonathan.huot@gmail.com>
Diffstat (limited to '')
-rw-r--r-- | inc/collectd.inc.php | 38 |
1 files changed, 17 insertions, 21 deletions
diff --git a/inc/collectd.inc.php b/inc/collectd.inc.php index d5a3d83..3c016af 100644 --- a/inc/collectd.inc.php +++ b/inc/collectd.inc.php | |||
@@ -33,13 +33,22 @@ function collectd_plugindata($host, $plugin=NULL) { | |||
33 | 33 | ||
34 | $data = array(); | 34 | $data = array(); |
35 | foreach($files as $item) { | 35 | foreach($files as $item) { |
36 | preg_match('#([\w_]+)(?:\-(.+))?/([\w_]+)(?:\-(.+))?\.rrd#', $item, $matches); | 36 | preg_match('` |
37 | (?P<p>[\w_]+) # plugin | ||
38 | (?:(?<=varnish)(?:\-(?P<c>[\w]+)))? # category | ||
39 | (?:\-(?P<pi>.+))? # plugin instance | ||
40 | / | ||
41 | (?P<t>[\w_]+) # type | ||
42 | (?:\-(?P<ti>.+))? # type instance | ||
43 | \.rrd | ||
44 | `x', $item, $matches); | ||
37 | 45 | ||
38 | $data[] = array( | 46 | $data[] = array( |
39 | 'p' => $matches[1], | 47 | 'p' => $matches['p'], |
40 | 'pi' => isset($matches[2]) ? $matches[2] : '', | 48 | 'c' => isset($matches['c']) ? $matches['c'] : '', |
41 | 't' => $matches[3], | 49 | 'pi' => isset($matches['pi']) ? $matches['pi'] : '', |
42 | 'ti' => isset($matches[4]) ? $matches[4] : '', | 50 | 't' => $matches['t'], |
51 | 'ti' => isset($matches['ti']) ? $matches['ti'] : '', | ||
43 | ); | 52 | ); |
44 | } | 53 | } |
45 | 54 | ||
@@ -70,7 +79,7 @@ function collectd_plugins($host) { | |||
70 | 79 | ||
71 | # returns an array of all pi/t/ti of an plugin | 80 | # returns an array of all pi/t/ti of an plugin |
72 | function collectd_plugindetail($host, $plugin, $detail, $where=NULL) { | 81 | function collectd_plugindetail($host, $plugin, $detail, $where=NULL) { |
73 | $details = array('pi', 't', 'ti'); | 82 | $details = array('pi', 'c', 't', 'ti'); |
74 | if (!in_array($detail, $details)) | 83 | if (!in_array($detail, $details)) |
75 | return false; | 84 | return false; |
76 | 85 | ||
@@ -122,11 +131,12 @@ function group_plugindata($plugindata) { | |||
122 | function plugin_sort($data) { | 131 | function plugin_sort($data) { |
123 | foreach ($data as $key => $row) { | 132 | foreach ($data as $key => $row) { |
124 | $pi[$key] = $row['pi']; | 133 | $pi[$key] = $row['pi']; |
134 | $c[$key] = $row['c']; | ||
125 | $ti[$key] = $row['ti']; | 135 | $ti[$key] = $row['ti']; |
126 | $t[$key] = $row['t']; | 136 | $t[$key] = $row['t']; |
127 | } | 137 | } |
128 | 138 | ||
129 | array_multisort($pi, SORT_ASC, $t, SORT_ASC, $ti, SORT_ASC, $data); | 139 | array_multisort($c, SORT_ASC, $pi, SORT_ASC, $t, SORT_ASC, $ti, SORT_ASC, $data); |
130 | 140 | ||
131 | return $data; | 141 | return $data; |
132 | } | 142 | } |
@@ -180,20 +190,6 @@ function build_url($base, $items, $s=NULL) { | |||
180 | return $base; | 190 | return $base; |
181 | } | 191 | } |
182 | 192 | ||
183 | # generate identifier that collectd's FLUSH command understands | ||
184 | function collectd_identifier($host, $plugin, $pinst, $type, $tinst) { | ||
185 | global $CONFIG; | ||
186 | |||
187 | $identifier = sprintf('%s/%s%s%s/%s%s%s', $host, | ||
188 | $plugin, strlen($pinst) ? '-' : '', $pinst, | ||
189 | $type, strlen($tinst) ? '-' : '', $tinst); | ||
190 | |||
191 | if (is_file($CONFIG['datadir'].'/'.$identifier.'.rrd')) | ||
192 | return $identifier; | ||
193 | else | ||
194 | return FALSE; | ||
195 | } | ||
196 | |||
197 | # tell collectd to FLUSH all data of the identifier(s) | 193 | # tell collectd to FLUSH all data of the identifier(s) |
198 | function collectd_flush($identifier) { | 194 | function collectd_flush($identifier) { |
199 | global $CONFIG; | 195 | global $CONFIG; |