#javascript #graphite #grafana
#javascript #графит #графана
Вопрос:
Я тестирую с помощью Grafana для чтения и отображения данных из системы Graphite.
Вот как Grafana ожидает данные json от Graphite:
{
"data": [
{
"target": "test-series-0",
"datapoints": [
[
22.504392773143504,
1.476693264195e 12
],
[
22.719552781746028,
1.476693301825e 12
]
]
}
]
}
Система, из которой я хочу считывать данные, меняет местами временную метку и значение показателя, например
{
"data": [
{
"target": "test-series-0",
"datapoints": [
[
1.476693264195e 12
22.504392773143504,
],
[
1.476693301825e 12
22.719552781746028,
]
]
}
]
}
Возможно ли создать новый источник данных (копию из источника данных graphite по умолчанию), который либо возвращает значения обратно перед обработкой, либо работает со значениями как есть?
Я просмотрел файлы .js, но мне трудно определить, где мне нужно внести изменения, поэтому любые указатели приветствуются!
РЕДАКТИРОВАТЬ: я пробовал это: я сделал копию плагина Graphite по умолчанию и переименовал его в graphite-copy и скорректировал идентификатор plugin.json
.
Затем я отредактировал datasource.js
и datasource.ts
вот так:
var e = {
method: "POST",
url: "/render",
data: d.join("amp;"),
headers: {
"Content-Type": "application/x-www-form-urlencoded"
}
};
return a.panelId amp;amp; (e.requestId = this.name ".panelId." a.panelId), this.doGraphiteRequest(e).then(this.convertDataPointsToMs)
}, this.convertDataPointsToMs = function(a) {
if (!a || !a.data) return [];
for (var b = 0; b < a.data.length; b )
for (var c = a.data[b], d = 0; d < c.datapoints.length; d ) {
var t = c.datapoints[d][0];
c.datapoints[d][0] = c.datapoints[d][1];
c.datapoints[d][0] = t;
c.datapoints[d][1] *= 1e3;
}
С учетом этого изменения:
var t = c.datapoints[d][0];
c.datapoints[d][0] = c.datapoints[d][1];
c.datapoints[d][0] = t;
Я сделал это как для методов GET, так и для POST datasource.js/ts
, но это дает мне тот же результат (временная метка и метрика переключены).
Ответ №1:
Вы можете сделать это примерно так, angular
используя angular.factory
var module = angular.module(grafana.services);
module.factory('Datasrc',function($q, backendsrv, templatesrv){
//$q,backendsrv templatesrv supported by grafana
function Datasrc(datasource){
this.type =// the datasource type;
this.url = datasource.url;
this.auth = datasource.basicAuth;
this.timestamp = true;
this.supportMetrics = true;
}
AtsdDatasource.prototype.query = function (options) {
var queries = _.compact(qs);
if (_.isEmpty(queries)) {
var d = $q.defer();
d.resolve({ data: [] });
return d.promise;
}
Datasrc.prototype._performQuery = function (queries) {
var query = [];
query.push(
{
data :[
objecttype = query.type,
datapoints = query.//swap the values here
//enter the other necessary fields or declare more in the factory
]
});
if (query.length === 0) {
var d = $q.defer();
d.resolve({ data: undefined });
return d.promise; //promise called here
}
var options = {
method: 'POST',
url: this.url '/api/v1/series',
data: {
queries: tsQueries
},
headers: {
Authorization: this.basicAuth
}
};
return backendSrv.datasourceRequest(options).then(function (result) {
return resu<
});
};
}
});
Полная атрибуция автору и ссылке на GitHub
Комментарии:
1. Завтра будет тест, куда это поместить?
2. то же самое в datasource.js , я также дал ссылку на github, вы можете изменять переменные в соответствии с вашим кодом, и вам нужно обернуть это в *promise
3. Я думаю, мне нужна более подробная информация о том, как реализовать предложенное вами решение, похоже, вы предлагаете полностью переписать datasource.js но я просто хочу произвести замену полей в массиве точек данных