Графит подкачки вернул временную метку и значение в Графане

#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 но я просто хочу произвести замену полей в массиве точек данных