Esta seção fornece detalhes de pré-processamento por JavaScript.
O pré-processamento JavaScript é feito pela invocação da função JavaScript com um único parâmetro 'valor' e um corpo de função fornecido pelo usuário. O resultado da etapa de pré-processamento é o valor retornado desta função, por exemplo, para executar a conversão de Fahrenheit para Celsius o usuário deve informar:
nos parâmetros de pré-processamento JavaScript, que será embutida em uma função JavaScript pelo Server:
O parâmetro de entrada 'valor' é sempre passado como um string. O valor de retorno é automaticamente forçado para um string através do método ToString() (se ele falhar então o erro é retornado como um valor string), com algumas poucas exceções:
Erros podem ser retornados pelo lançamento de valores/objetos (normalmente strings ou objetos Erro).
Por exemplo:
Cada script tem um tempo limite de execução de 10 segundos (dependendo do script pode ser levado mais tempo que o limite para engatilhar); excedê-lo retornará um erro. Um limite de heap de 64 megabyte é imposto.
O bytecode da etapa de pré-processamento JavaScript é guardado em cache e reutilizado quando a etapa é aplicada na próxima vez. Quaisquer alterações às etapas de pré-processamento do item farão com que o script em cache seja redefinido e recompilado posteriormente.
Falhas em tempo de execução consecutivas (3 em sequência) farão com que o mecanismo seja reiniciado para mitigar a possibilidade de um script quebrar a execução dos próximos scripts (esta ação é registrada em log com DebugLevel 4 e maior).
O pré-processamento JavaScript é implementado com o mecanismo JavaScript Duktape (https://duktape.org/).
Veja também: Objetos JavaScript adicionais e funções globais
É possível usar macros de usuário no código JavaScript. Se um script contém macros de usuário, estas macros são resolvidas pelo Server/Proxy antes da execução das etapas de pré-processamento específicas. Note que quando testando etapas de pré-processamento no Frontend, os valores de macro não serão puxados e precisam ser informados manualmente.
O contexto é ignorado quando uma macro é substituída com seu valor. O valor da macro é inserido no código como está, não é possível adicionar escapes adicionais antes de colocar o valor no código JavaScript. Por favor, esteja ciente que isto pode causar erros de JavaScript em alguns casos.
Em um exemplo abaixo, se o valor recebido excede um valor de {$THRESHOLD} de macro, o valor de threshold (se presente) será retornado em vez disso:
var threshold = '{$THRESHOLD}'; return (!isNaN(threshold) && value > threshold) ? threshold : value;
The following examples illustrate how you can use JavaScript preprocessing. Each example contains a brief description, a function body for JavaScript preprocessing parameters, and the preprocessing step result (value accepted by the function → value returned by the function).
Convert a number from scientific notation to an integer.
Result: 2.62128e+07 → 26212800
Convert a binary number to a decimal number.
Result: 11010010 → 210
Round a number to 2 digits.
Result: 18.2345 → 18.23
Count the number of letters in a string.
Result: "zabbix" → 6
Get the remaining time (in seconds) until the expiration date of a certificate.
var split = value.split(' '), MONTHS_LIST = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'], month_index = ('0' + (MONTHS_LIST.indexOf(split[0]) + 1)).slice(-2), ISOdate = split[3] + '-' + month_index + '-' + split[1] + 'T' + split[2], now = Date.now(); return parseInt((Date.parse(ISOdate) - now) / 1000);
Result: Feb 12 12:33:56 2022 GMT → 44380233
Modify a JSON data structure by removing any properties with the key "data_size"
or "index_size"
.
var obj=JSON.parse(value); for (i = 0; i < Object.keys(obj).length; i++) { delete obj[i]["data_size"]; delete obj[i]["index_size"]; } return JSON.stringify(obj)
Value accepted by the function:
[ { "table_name":"history", "data_size":"326.05", "index_size":"174.34" }, { "table_name":"history_log", "data_size":"6.02", "index_size":"3.45" } ]
Value returned by the function:
Convert the value received from a web.page.get Zabbix agent item (e.g., web.page.get[http://127.0.0.1:80/server-status?auto]) to a JSON object.
// Convert Apache status to JSON // Split the value into substrings and put these substrings into an array var lines = value.split('\n'); // Create an empty object "output" var output = {}; // Create an object "workers" with predefined properties var workers = { '_': 0, 'S': 0, 'R': 0, 'W': 0, 'K': 0, 'D': 0, 'C': 0, 'L': 0, 'G': 0, 'I': 0, '.': 0 }; // Add the substrings from the "lines" array to the "output" object as properties (key-value pairs) for (var i = 0; i < lines.length; i++) { var line = lines[i].match(/([A-z0-9 ]+): (.*)/); if (line !== null) { output[line[1]] = isNaN(line[2]) ? line[2] : Number(line[2]); } } // Multiversion metrics output.ServerUptimeSeconds = output.ServerUptimeSeconds || output.Uptime; output.ServerVersion = output.ServerVersion || output.Server; // Parse "Scoreboard" property to get the worker count if (typeof output.Scoreboard === 'string') { for (var i = 0; i < output.Scoreboard.length; i++) { var char = output.Scoreboard[i]; workers[char]++; } } // Add worker data to the "output" object output.Workers = { waiting: workers['_'], starting: workers['S'], reading: workers['R'], sending: workers['W'], keepalive: workers['K'], dnslookup: workers['D'], closing: workers['C'], logging: workers['L'], finishing: workers['G'], cleanup: workers['I'], slot: workers['.'] }; // Return JSON string return JSON.stringify(output);
Value accepted by the function:
HTTP/1.1 200 OK Date: Mon, 27 Mar 2023 11:08:39 GMT Server: Apache/2.4.52 (Ubuntu) Vary: Accept-Encoding Content-Encoding: gzip Content-Length: 405 Content-Type: text/plain; charset=ISO-8859-1 127.0.0.1 ServerVersion: Apache/2.4.52 (Ubuntu) ServerMPM: prefork Server Built: 2023-03-08T17:32:01 CurrentTime: Monday, 27-Mar-2023 14:08:39 EEST RestartTime: Monday, 27-Mar-2023 12:19:59 EEST ParentServerConfigGeneration: 1 ParentServerMPMGeneration: 0 ServerUptimeSeconds: 6520 ServerUptime: 1 hour 48 minutes 40 seconds Load1: 0.56 Load5: 0.33 Load15: 0.28 Total Accesses: 2476 Total kBytes: 8370 Total Duration: 52718 CPUUser: 8.16 CPUSystem: 3.44 CPUChildrenUser: 0 CPUChildrenSystem: 0 CPULoad: .177914 Uptime: 6520 ReqPerSec: .379755 BytesPerSec: 3461.58 BytesPerReq: 3461.58 DurationPerReq: 21.2916 BusyWorkers: 2 IdleWorkers: 6 Scoreboard: ____KW__..............................................................................................................................................
Value returned by the function:
{ "Date": "Mon, 27 Mar 2023 11:08:39 GMT", "Server": "Apache/2.4.52 (Ubuntu)", "Vary": "Accept-Encoding", "Encoding": "gzip", "Length": 405, "Type": "text/plain; charset=ISO-8859-1", "ServerVersion": "Apache/2.4.52 (Ubuntu)", "ServerMPM": "prefork", "Server Built": "2023-03-08T17:32:01", "CurrentTime": "Monday, 27-Mar-2023 14:08:39 EEST", "RestartTime": "Monday, 27-Mar-2023 12:19:59 EEST", "ParentServerConfigGeneration": 1, "ParentServerMPMGeneration": 0, "ServerUptimeSeconds": 6520, "ServerUptime": "1 hour 48 minutes 40 seconds", "Load1": 0.56, "Load5": 0.33, "Load15": 0.28, "Total Accesses": 2476, "Total kBytes": 8370, "Total Duration": 52718, "CPUUser": 8.16, "CPUSystem": 3.44, "CPUChildrenUser": 0, "CPUChildrenSystem": 0, "CPULoad": 0.177914, "Uptime": 6520, "ReqPerSec": 0.379755, "BytesPerSec": 1314.55, "BytesPerReq": 3461.58, "DurationPerReq": 21.2916, "BusyWorkers": 2, "IdleWorkers": 6, "Scoreboard": "____KW__..............................................................................................................................................", "Workers": { "waiting": 6, "starting": 0, "reading": 0, "sending": 1, "keepalive": 1, "dnslookup": 0, "closing": 0, "logging": 0, "finishing": 0, "cleanup": 0, "slot": 142 } }