mirror of
https://github.com/prometheus/statsd_exporter.git
synced 2025-01-25 21:58:08 +00:00
Break out mapkey generation into function
Signed-off-by: Vitaliy Sakhartchouk <vsakhart@github.com>
This commit is contained in:
parent
2025b47cb1
commit
2fc89536f4
1 changed files with 12 additions and 8 deletions
20
exporter.go
20
exporter.go
|
@ -69,6 +69,10 @@ func getLabelNames(labels prometheus.Labels) []string {
|
||||||
return names
|
return names
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func getContainerMapKey(metricName string, labelNames []string) string {
|
||||||
|
return metricName + "," + strings.Join(labelNames, ",")
|
||||||
|
}
|
||||||
|
|
||||||
// hashNameAndLabels returns a hash value of the provided name string and all
|
// hashNameAndLabels returns a hash value of the provided name string and all
|
||||||
// the label names and values in the provided labels map.
|
// the label names and values in the provided labels map.
|
||||||
//
|
//
|
||||||
|
@ -97,7 +101,7 @@ func NewCounterContainer() *CounterContainer {
|
||||||
|
|
||||||
func (c *CounterContainer) Get(metricName string, labels prometheus.Labels, help string) (prometheus.Counter, error) {
|
func (c *CounterContainer) Get(metricName string, labels prometheus.Labels, help string) (prometheus.Counter, error) {
|
||||||
labelNames := getLabelNames(labels)
|
labelNames := getLabelNames(labels)
|
||||||
mapKey := metricName + "," + strings.Join(labelNames, ",")
|
mapKey := getContainerMapKey(metricName, labelNames)
|
||||||
|
|
||||||
counterVec, ok := c.Elements[mapKey]
|
counterVec, ok := c.Elements[mapKey]
|
||||||
if !ok {
|
if !ok {
|
||||||
|
@ -115,7 +119,7 @@ func (c *CounterContainer) Get(metricName string, labels prometheus.Labels, help
|
||||||
|
|
||||||
func (c *CounterContainer) Delete(metricName string, labels prometheus.Labels) {
|
func (c *CounterContainer) Delete(metricName string, labels prometheus.Labels) {
|
||||||
labelNames := getLabelNames(labels)
|
labelNames := getLabelNames(labels)
|
||||||
mapKey := metricName + "," + strings.Join(labelNames, ",")
|
mapKey := getContainerMapKey(metricName, labelNames)
|
||||||
if _, ok := c.Elements[mapKey]; ok {
|
if _, ok := c.Elements[mapKey]; ok {
|
||||||
c.Elements[mapKey].Delete(labels)
|
c.Elements[mapKey].Delete(labels)
|
||||||
}
|
}
|
||||||
|
@ -133,7 +137,7 @@ func NewGaugeContainer() *GaugeContainer {
|
||||||
|
|
||||||
func (c *GaugeContainer) Get(metricName string, labels prometheus.Labels, help string) (prometheus.Gauge, error) {
|
func (c *GaugeContainer) Get(metricName string, labels prometheus.Labels, help string) (prometheus.Gauge, error) {
|
||||||
labelNames := getLabelNames(labels)
|
labelNames := getLabelNames(labels)
|
||||||
mapKey := metricName + "," + strings.Join(labelNames, ",")
|
mapKey := getContainerMapKey(metricName, labelNames)
|
||||||
|
|
||||||
gaugeVec, ok := c.Elements[mapKey]
|
gaugeVec, ok := c.Elements[mapKey]
|
||||||
if !ok {
|
if !ok {
|
||||||
|
@ -151,7 +155,7 @@ func (c *GaugeContainer) Get(metricName string, labels prometheus.Labels, help s
|
||||||
|
|
||||||
func (c *GaugeContainer) Delete(metricName string, labels prometheus.Labels) {
|
func (c *GaugeContainer) Delete(metricName string, labels prometheus.Labels) {
|
||||||
labelNames := getLabelNames(labels)
|
labelNames := getLabelNames(labels)
|
||||||
mapKey := metricName + "," + strings.Join(labelNames, ",")
|
mapKey := getContainerMapKey(metricName, labelNames)
|
||||||
if _, ok := c.Elements[mapKey]; ok {
|
if _, ok := c.Elements[mapKey]; ok {
|
||||||
c.Elements[mapKey].Delete(labels)
|
c.Elements[mapKey].Delete(labels)
|
||||||
}
|
}
|
||||||
|
@ -171,7 +175,7 @@ func NewSummaryContainer(mapper *mapper.MetricMapper) *SummaryContainer {
|
||||||
|
|
||||||
func (c *SummaryContainer) Get(metricName string, labels prometheus.Labels, help string, mapping *mapper.MetricMapping) (prometheus.Observer, error) {
|
func (c *SummaryContainer) Get(metricName string, labels prometheus.Labels, help string, mapping *mapper.MetricMapping) (prometheus.Observer, error) {
|
||||||
labelNames := getLabelNames(labels)
|
labelNames := getLabelNames(labels)
|
||||||
mapKey := metricName + "," + strings.Join(labelNames, ",")
|
mapKey := getContainerMapKey(metricName, labelNames)
|
||||||
|
|
||||||
summaryVec, ok := c.Elements[mapKey]
|
summaryVec, ok := c.Elements[mapKey]
|
||||||
if !ok {
|
if !ok {
|
||||||
|
@ -199,7 +203,7 @@ func (c *SummaryContainer) Get(metricName string, labels prometheus.Labels, help
|
||||||
|
|
||||||
func (c *SummaryContainer) Delete(metricName string, labels prometheus.Labels) {
|
func (c *SummaryContainer) Delete(metricName string, labels prometheus.Labels) {
|
||||||
labelNames := getLabelNames(labels)
|
labelNames := getLabelNames(labels)
|
||||||
mapKey := metricName + "," + strings.Join(labelNames, ",")
|
mapKey := getContainerMapKey(metricName, labelNames)
|
||||||
if _, ok := c.Elements[mapKey]; ok {
|
if _, ok := c.Elements[mapKey]; ok {
|
||||||
c.Elements[mapKey].Delete(labels)
|
c.Elements[mapKey].Delete(labels)
|
||||||
}
|
}
|
||||||
|
@ -219,7 +223,7 @@ func NewHistogramContainer(mapper *mapper.MetricMapper) *HistogramContainer {
|
||||||
|
|
||||||
func (c *HistogramContainer) Get(metricName string, labels prometheus.Labels, help string, mapping *mapper.MetricMapping) (prometheus.Observer, error) {
|
func (c *HistogramContainer) Get(metricName string, labels prometheus.Labels, help string, mapping *mapper.MetricMapping) (prometheus.Observer, error) {
|
||||||
labelNames := getLabelNames(labels)
|
labelNames := getLabelNames(labels)
|
||||||
mapKey := metricName + "," + strings.Join(labelNames, ",")
|
mapKey := getContainerMapKey(metricName, labelNames)
|
||||||
|
|
||||||
histogramVec, ok := c.Elements[mapKey]
|
histogramVec, ok := c.Elements[mapKey]
|
||||||
if !ok {
|
if !ok {
|
||||||
|
@ -243,7 +247,7 @@ func (c *HistogramContainer) Get(metricName string, labels prometheus.Labels, he
|
||||||
|
|
||||||
func (c *HistogramContainer) Delete(metricName string, labels prometheus.Labels) {
|
func (c *HistogramContainer) Delete(metricName string, labels prometheus.Labels) {
|
||||||
labelNames := getLabelNames(labels)
|
labelNames := getLabelNames(labels)
|
||||||
mapKey := metricName + "," + strings.Join(labelNames, ",")
|
mapKey := getContainerMapKey(metricName, labelNames)
|
||||||
if _, ok := c.Elements[mapKey]; ok {
|
if _, ok := c.Elements[mapKey]; ok {
|
||||||
c.Elements[mapKey].Delete(labels)
|
c.Elements[mapKey].Delete(labels)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue