heatmap_metric_mapreduce.js 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. /**
  2. * Licensed to the Apache Software Foundation (ASF) under one or more
  3. * contributor license agreements. See the NOTICE file distributed with this
  4. * work for additional information regarding copyright ownership. The ASF
  5. * licenses this file to you under the Apache License, Version 2.0 (the
  6. * "License"); you may not use this file except in compliance with the License.
  7. * You may obtain a copy of the License at
  8. *
  9. * http://www.apache.org/licenses/LICENSE-2.0
  10. *
  11. * Unless required by applicable law or agreed to in writing, software
  12. * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
  13. * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
  14. * License for the specific language governing permissions and limitations under
  15. * the License.
  16. */
  17. var App = require('app');
  18. /**
  19. * Base class for any MapReduce metric.
  20. */
  21. App.MainChartHeatmapMapreduceMetrics = App.MainChartHeatmapMetric.extend({
  22. ajaxIndex: 'hosts.metrics.host_component',
  23. ajaxData: {
  24. serviceName: 'MAPREDUCE',
  25. componentName: 'TASKTRACKER'
  26. },
  27. /**
  28. * Custom mapper for MapReduce metrics
  29. */
  30. metricMapper: function(json) {
  31. return this.metricMapperWithTransform(json, this.get('defaultMetric'), this.get('transformValue'));
  32. },
  33. /**
  34. * Utility function which allows extending classes to transform the value
  35. * assigned to a host.
  36. *
  37. * @Function
  38. */
  39. transformValue: null
  40. });