Els càlculs agregats són de tipus element calculat i permeten la recollida informació de diversos elements per el servidor Zabbix i calcular un agregat, segons la funció d'agregat emprada.
Els càlculs agregats no necessiten cap agent executant-se a l'equip monitorat.
Per recuperar agregats, empreu una de les funcions afegides: avg
, max
, min
, sum
, etc. Tot seguit, afegiu la funció foreach com a únic paràmetre i el seu filtre d'elements per triar els elements necessaris:
Una funció foreach (per exemple, avg_foreach, count_foreach, etc.) retorna un valor agregat per a cada element seleccionat. Els elements es trien mitjançant el filtre d'elements (/host/key?[group="grup d'equips"]
), de l'historial d'elements. Per a més detalls, veieu les funcions foreach.
Si alguns dels elements no tenen dades per al període triat, s'ignoren en el càlcul. Si no hi ha dades dels elements, la funció retornarà un error.
Alternativament, podeu enumerar diversos elements com a paràmetres per a l'agregació:
Tingueu en compte que la "funció" aquí ha d'ésser una funció d'historial/tendència.
Si l'agregat dóna com a resultat un valor flotant, s'escurçarà a un nombre enter si el tipus d'informació d'element agregat és Numèric (sense signe).
Les macros d'usuari i les macros de descoberta de baix nivell s'admeten a:
Un càlcul agregat pot no ser compatible si:
Exemples de claus per als càlculs agregats.
Espai total de disc del grup d'equips 'MySQL Servers'.
Suma dels darrers valors de tots els elements que corresponen a net.if.in[*] sota l'equip.
Càrrega mitjana de processador del grup d'equips 'MySQL Servers'.
Mitjana de 5 minuts del nombre de peticions per segon del grup d'equips 'MySQL Servers'.
Càrrega mitjana de CPU de tots els equips a diversos grups d'equips que tenen unes etiquetes concretes.
avg(last_foreach(/*/system.cpu.load?[(group="Servers A" or group="Servers B" or group="Servers C") and (tag="Service:" or tag="Importance:High")]))
Càlcul emprat sota les darreres sumes de valor d'element d'un grup d'equips sencer.
sum(last_foreach(/*/net.if.out[eth0,bytes]?[group="video"])) / sum(last_foreach(/*/nginx_stat.sh[active]?[group="video"]))
Nombre total d'elements no admesos al grup d'equips 'Zabbix servers'.
Les expressions (incloses les crides a funcions) no es poden pas emprar com a paràmetres d'històric, de tendència o de la funció foreach. Tanmateix, les pròpies funcions poden emprar-se dins d'altres paràmetres de funció (no històriques).
Expressió | Exemple |
---|---|
Vàlid | avg(last(/host/key1),last(/host/key2)*10,last(/host/key1)*100) max(avg(avg_foreach(/*/system.cpu.load?[group="Servers A"],5m)),avg(avg_foreach(/*/system.cpu.load?[group="Servers B"],5m)),avg(avg_foreach(/*/system.cpu.load?[group="Servers C"],5m))) |
No vàlid | sum(/host/key,10+2) sum(/host/key, avg(10,2)) sum(/host/key,last(/host/key2)) |
Veieu que en una expressió com ara:
no es pot garantir que les dues parts de l'equació tinguin sempre el mateix conjunt de valors. Mentre una part de l'expressió és avaluada, pota arribar un valor nou per al període demanat, i llavors l'altra part de l'expressió tindrà un conjunt de valors diferent.