2023-01-27 21:37:20 +00:00
|
|
|
// Copyright (c) Tailscale Inc & AUTHORS
|
|
|
|
// SPDX-License-Identifier: BSD-3-Clause
|
2020-03-03 19:33:22 +00:00
|
|
|
|
|
|
|
// Package metrics contains expvar & Prometheus types and code used by
|
|
|
|
// Tailscale for monitoring.
|
|
|
|
package metrics
|
|
|
|
|
|
|
|
import "expvar"
|
|
|
|
|
2020-03-04 20:24:07 +00:00
|
|
|
// Set is a string-to-Var map variable that satisfies the expvar.Var
|
2020-03-03 19:33:22 +00:00
|
|
|
// interface.
|
|
|
|
//
|
|
|
|
// Semantically, this is mapped by tsweb's Prometheus exporter as a
|
|
|
|
// collection of unrelated variables exported with a common prefix.
|
|
|
|
//
|
|
|
|
// This lets us have tsweb recognize *expvar.Map for different
|
|
|
|
// purposes in the future. (Or perhaps all uses of expvar.Map will
|
|
|
|
// require explicit types like this one, declaring how we want tsweb
|
|
|
|
// to export it to Prometheus.)
|
|
|
|
type Set struct {
|
|
|
|
expvar.Map
|
|
|
|
}
|
2020-03-04 20:24:07 +00:00
|
|
|
|
|
|
|
// LabelMap is a string-to-Var map variable that satisfies the
|
|
|
|
// expvar.Var interface.
|
|
|
|
//
|
|
|
|
// Semantically, this is mapped by tsweb's Prometheus exporter as a
|
|
|
|
// collection of variables with the same name, with a varying label
|
|
|
|
// value. Use this to export things that are intuitively breakdowns
|
|
|
|
// into different buckets.
|
|
|
|
type LabelMap struct {
|
|
|
|
Label string
|
|
|
|
expvar.Map
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get returns a direct pointer to the expvar.Int for key, creating it
|
|
|
|
// if necessary.
|
|
|
|
func (m *LabelMap) Get(key string) *expvar.Int {
|
|
|
|
m.Add(key, 0)
|
|
|
|
return m.Map.Get(key).(*expvar.Int)
|
|
|
|
}
|
2020-07-19 20:31:12 +01:00
|
|
|
|
|
|
|
// GetFloat returns a direct pointer to the expvar.Float for key, creating it
|
|
|
|
// if necessary.
|
|
|
|
func (m *LabelMap) GetFloat(key string) *expvar.Float {
|
|
|
|
m.AddFloat(key, 0.0)
|
|
|
|
return m.Map.Get(key).(*expvar.Float)
|
|
|
|
}
|
2021-09-02 19:14:14 +01:00
|
|
|
|
|
|
|
// CurrentFDs reports how many file descriptors are currently open.
|
|
|
|
//
|
|
|
|
// It only works on Linux. It returns zero otherwise.
|
|
|
|
func CurrentFDs() int {
|
|
|
|
return currentFDs()
|
|
|
|
}
|