File: opentsdb.go

package info (click to toggle)
golang-github-spacejam-loghisto 0.0~git20150819.0.3233097-2
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye, buster, forky, sid, trixie
  • size: 120 kB
  • sloc: makefile: 4
file content (85 lines) | stat: -rw-r--r-- 2,137 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
// Copyright 2014 The Cockroach Authors.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
// implied.  See the License for the specific language governing
// permissions and limitations under the License. See the AUTHORS file
// for names of contributors.
//
// Author: Tyler Neely (t@jujit.su)

package loghisto

import (
	"bytes"
	"fmt"
	"os"
	"strings"

)

type openTSDBStat struct {
	Metric string
	Time   int64
	Value  float64
	Tags   map[string]string
}

type openTSDBStatArray []*openTSDBStat

func mapToTSDProtocolTags(tagMap map[string]string) string {
	tags := make([]string, 0, len(tagMap))
	for tag, value := range tagMap {
		tags = append(tags, fmt.Sprintf("%s=%s", tag, value))
	}
	return strings.Join(tags, " ")
}

func (stats openTSDBStatArray) ToRequest() []byte {
	var request bytes.Buffer
	for _, stat := range stats {
		request.Write([]byte(fmt.Sprintf("put %s %d %f %s\n",
			stat.Metric,
			stat.Time,
			stat.Value,
			mapToTSDProtocolTags(stat.Tags))))
	}
	return []byte(request.String())
}

func (metricSet *ProcessedMetricSet) toopenTSDBStats() openTSDBStatArray {
	hostname, err := os.Hostname()
	if err != nil {
		hostname = "unknown"
	}

	stats := make([]*openTSDBStat, 0, len(metricSet.Metrics))
	i := 0
	for metric, value := range metricSet.Metrics {
		var tags = map[string]string{
			"host": hostname,
		}
		//TODO(tyler) custom tags
		stats = append(stats, &openTSDBStat{
			Metric: metric,
			Time:   metricSet.Time.Unix(),
			Value:  value,
			Tags:   tags,
		})
		i++
	}
	return stats
}

// OpenTSDBProtocol generates a wire representation of a ProcessedMetricSet
// for submission to an OpenTSDB instance.
func OpenTSDBProtocol(ms *ProcessedMetricSet) []byte {
	return ms.toopenTSDBStats().ToRequest()
}