Назад | Перейти на главную страницу

Файл агрегированных графиков Мунина пуст

Я не могу агрегировать некоторые написанные мной пользовательские графики. Я знаю, что агрегирование работает, потому что я могу агрегировать плагины по умолчанию, но я не уверен, что не так с моим.

munin.conf:

[myapp;web-servers;0-1]
        address 1.2.3.4
        use_node_name yes
[myapp;web-servers;0-2]
        address 5.6.7.8
        use_node_name yes

[myapp;web-servers;Aggregated]
        update no

#does not work:
    node_aggregate.graph_args --base 1000 -l 0
    node_aggregate.graph_title Aggregated connects
    node_aggregate.conns.label conns
    node_aggregate.conns.sum myapp;web-servers;0-1:nodejs_numberOfConnects.conns myapp;web-servers;0-2:nodejs_numberOfConnects.conns


#works:
    node_aggregate.graph_title Aggregated cpu
    node_aggregate.cpu.label cpu.user
    node_aggregate.cpu.sum myapp;web-servers;0-1:cpu.user myapp;web-servers;0-2:cpu.user

Мои плагины выглядят так:

if [[ "$PARAM" == "numberOfConnects" ]]; then
        echo "graph_title Active Connects";
        echo "graph_info Active Connects";
        echo "graph_vlabel Connections";
        echo "$PARAM.label conns";
        echo "$PARAM.type GAUGE";
        echo "$PARAM.colour 0927EB"
        exit 0;
elif ...
fi
echo $PARAM.value 15

В целях тестирования я могу жестко указать "$ PARAM.value 15". Тогда я могу сделать
munin-run --servicedir /etc/munin/plugins nodejs_numberOfConnects который вернется numberOfConnects.value 15

И ошибка, которую я получаю:

==> /var/log/munin/munin-graph.log <==
2016/03/15 13:57:01 [ERROR] filename is empty for $VAR1 = {
  '#%#name' => 'z1_0',
  'cdef' => 'z1_0,UN,0,z1_0,IF',
  'graph' => 'no',
  'label' => 'z1_0'
};
, myapp;web-servers;0-1:nodejs_numberOfConnects.conns

2016/03/15 13:57:01 [ERROR] filename is empty for $VAR1 = {
  '#%#name' => 'z1_1',
  'cdef' => 'z1_1,UN,0,z1_1,IF,z1_0,ADDNAN',
  'colour' => undef,
  'draw' => undef,
  'graph' => 'yes',
  'label' => 'conns'
};
, myapp;web-servers;0-2:nodejs_numberOfConnects.conns

После долгой отладки я понял, что неправильно использую имя метка вместо названия стоимость.

node_aggregate.conns.sum myapp;web-servers;0-1:nodejs_numberOfConnects.conns myapp;web-servers;0-2:nodejs_numberOfConnects.conns

должно быть

node_aggregate.conns.sum myapp;web-servers;0-1:nodejs_numberOfConnects.numberOfConnects myapp;web-servers;0-2:nodejs_numberOfConnects.numberOfConnects

из-за

if [[ "$PARAM" == "numberOfConnects" ]]; then
[...]
echo $PARAM.value 15

Другими словами, в моем случае строка сервера равна:
$arbitraryname1.arbitraryname2.sum $clientname;$hostgroup;$hostname:$pluginname.$valuename

Меня также сильно выбросило cpu пример, в котором используется следующий синтаксис:
myapp;web-servers;0-1:cpu.user но это потому, что его имя значения фактически совпадает с именем метки !!

Вы пытаетесь пройти conns как экспортируемое значение, но это на самом деле numberOfConnects

node_aggregate.nodejs_numberOfConnects.label conns(or whatever)
node_aggregate.nodejs_numberOfConnects.sum \ 
    myapp;web-servers;0-1:nodejs_numberOfConnects.numberOfConnects \ 
    myapp;web-servers;0-2:nodejs_numberOfConnects.numberOfConnects