
Corrected the gotemplate range call Modified the wrapper class Delete test/instrumentation/documentation/documentation.md Removed documentation.md change as we're changing it over the other PR Restored the original doc.md ; PR is solely for the generator code now Some label fixes merge commits
221 lines
9.3 KiB
Go
Executable File
221 lines
9.3 KiB
Go
Executable File
/*
|
|
Copyright 2020 The Kubernetes 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.
|
|
*/
|
|
|
|
package main
|
|
|
|
import (
|
|
"bytes"
|
|
"fmt"
|
|
"os"
|
|
"sort"
|
|
"strings"
|
|
"text/template"
|
|
"time"
|
|
|
|
flag "github.com/spf13/pflag"
|
|
"gopkg.in/yaml.v2"
|
|
|
|
"k8s.io/component-base/metrics"
|
|
)
|
|
|
|
var (
|
|
GOROOT string = os.Getenv("GOROOT")
|
|
GOOS string = os.Getenv("GOOS")
|
|
KUBE_ROOT string = os.Getenv("KUBE_ROOT")
|
|
funcMap = template.FuncMap{
|
|
"ToLower": strings.ToLower,
|
|
}
|
|
)
|
|
|
|
const (
|
|
templ = `---
|
|
title: Kubernetes Metrics Reference
|
|
content_type: reference
|
|
auto_generated: true
|
|
description: >-
|
|
Details of the metric data that Kubernetes components export.
|
|
---
|
|
|
|
## Metrics (v{{.GeneratedVersion}})
|
|
|
|
<!-- (auto-generated {{.GeneratedDate.Format "2006 Jan 02"}}) -->
|
|
<!-- (auto-generated v{{.GeneratedVersion}}) -->
|
|
This page details the metrics that different Kubernetes components export. You can query the metrics endpoint for these
|
|
components using an HTTP scrape, and fetch the current metrics data in Prometheus format.
|
|
|
|
### List of Stable Kubernetes Metrics
|
|
|
|
Stable metrics observe strict API contracts and no labels can be added or removed from stable metrics during their lifetime.
|
|
|
|
<div class="metrics">
|
|
{{- range $index, $metric := .StableMetrics -}}
|
|
<div class="metric" data-stability="{{$metric.StabilityLevel | ToLower}}">
|
|
<div class="metric_name">{{with $metric}}{{.BuildFQName}}{{- end -}}</div>
|
|
<div class="metric_help">{{- $metric.Help -}}</div>
|
|
<ul>
|
|
<li><label class="metric_detail">Stability Level:</label><span class="metric_stability_level">{{- $metric.StabilityLevel -}}</span></li>
|
|
<li data-type="{{$metric.Type | ToLower}}"><label class="metric_detail">Type:</label> <span class="metric_type">{{- $metric.Type -}}</span></li>
|
|
{{if $metric.Labels }}<li class="metric_labels_varying"><label class="metric_detail">Labels:</label>{{range $label := $metric.Labels}}<span class="metric_label">{{- $label -}}</span>{{- end -}}</li>{{- end -}}
|
|
{{if $metric.ConstLabels }}<li class="metric_labels_constant"><label class="metric_detail">Const Labels:</label>{{range $key, $value := $metric.ConstLabels}}<span class="metric_label">{{$key}}:{{$value}}</span>{{- end -}}</li>{{- end -}}
|
|
{{if $metric.DeprecatedVersion }}<li class="metric_deprecated_version"><label class="metric_detail">Deprecated Versions:</label><span>{{- $metric.DeprecatedVersion -}}</span></li>{{- end -}}
|
|
</ul>
|
|
</div>{{end}}
|
|
</div>
|
|
|
|
### List of Beta Kubernetes Metrics
|
|
|
|
Beta metrics observe a looser API contract than its stable counterparts. No labels can be removed from beta metrics during their lifetime, however, labels can be added while the metric is in the beta stage. This offers the assurance that beta metrics will honor existing dashboards and alerts, while allowing for amendments in the future.
|
|
|
|
<div class="metrics">
|
|
{{- range $index, $metric := .BetaMetrics -}}
|
|
<div class="metric" data-stability="{{$metric.StabilityLevel | ToLower}}">
|
|
<div class="metric_name">{{with $metric}}{{.BuildFQName}}{{- end -}}</div>
|
|
<div class="metric_help">{{- $metric.Help -}}</div>
|
|
<ul>
|
|
<li><label class="metric_detail">Stability Level:</label><span class="metric_stability_level">{{- $metric.StabilityLevel -}}</span></li>
|
|
<li data-type="{{$metric.Type | ToLower}}"><label class="metric_detail">Type:</label> <span class="metric_type">{{- $metric.Type -}}</span></li>
|
|
{{if $metric.Labels }}<li class="metric_labels_varying"><label class="metric_detail">Labels:</label>{{range $label := $metric.Labels}}<span class="metric_label">{{- $label -}}</span>{{- end -}}</li>{{- end -}}
|
|
{{if $metric.ConstLabels }}<li class="metric_labels_constant"><label class="metric_detail">Const Labels:</label>{{range $key, $value := $metric.ConstLabels}}<span class="metric_label">{{$key}}:{{$value}}</span>{{- end -}}</li>{{- end -}}
|
|
{{if $metric.DeprecatedVersion }}<li class="metric_deprecated_version"><label class="metric_detail">Deprecated Versions:</label><span>{{- $metric.DeprecatedVersion -}}</span></li>{{- end -}}
|
|
</ul>
|
|
</div>{{end}}
|
|
</div>
|
|
|
|
### List of Alpha Kubernetes Metrics
|
|
|
|
Alpha metrics do not have any API guarantees. These metrics must be used at your own risk, subsequent versions of Kubernetes may remove these metrics altogether, or mutate the API in such a way that breaks existing dashboards and alerts.
|
|
|
|
<div class="metrics">
|
|
{{- range $index, $metric := .AlphaMetrics -}}
|
|
<div class="metric" data-stability="{{$metric.StabilityLevel | ToLower}}">
|
|
<div class="metric_name">{{with $metric}}{{.BuildFQName}}{{- end -}}</div>
|
|
<div class="metric_help">{{- $metric.Help -}}</div>
|
|
<ul>
|
|
<li><label class="metric_detail">Stability Level:</label><span class="metric_stability_level">{{- $metric.StabilityLevel -}}</span></li>
|
|
<li data-type="{{$metric.Type | ToLower}}"><label class="metric_detail">Type:</label> <span class="metric_type">{{- $metric.Type -}}</span></li>
|
|
{{if $metric.Labels }}<li class="metric_labels_varying"><label class="metric_detail">Labels:</label>{{range $label := $metric.Labels}}<span class="metric_label">{{- $label -}}</span>{{- end -}}</li>{{- end -}}
|
|
{{if $metric.ConstLabels }}<li class="metric_labels_constant"><label class="metric_detail">Const Labels:</label>{{range $key, $value := $metric.ConstLabels}}<span class="metric_label">{{$key}}:{{$value}}</span>{{- end -}}</li>{{- end -}}
|
|
{{if $metric.DeprecatedVersion }}<li class="metric_deprecated_version"><label class="metric_detail">Deprecated Versions:</label><span>{{- $metric.DeprecatedVersion -}}</span></li>{{- end -}}
|
|
</ul>
|
|
</div>{{end}}
|
|
</div>
|
|
`
|
|
)
|
|
|
|
type templateData struct {
|
|
AlphaMetrics []metric
|
|
BetaMetrics []metric
|
|
StableMetrics []metric
|
|
GeneratedDate time.Time
|
|
GeneratedVersion string
|
|
}
|
|
|
|
func main() {
|
|
var major string
|
|
var minor string
|
|
flag.StringVar(&major, "major", "", "k8s major version")
|
|
flag.StringVar(&minor, "minor", "", "k8s minor version")
|
|
flag.Parse()
|
|
println(major, minor)
|
|
dat, err := os.ReadFile("test/instrumentation/documentation/documentation-list.yaml")
|
|
if err == nil {
|
|
var parsedMetrics []metric
|
|
err = yaml.Unmarshal(dat, &parsedMetrics)
|
|
if err != nil {
|
|
println("err", err)
|
|
}
|
|
sort.Sort(byFQName(parsedMetrics))
|
|
t := template.New("t").Funcs(funcMap)
|
|
t, err := t.Parse(templ)
|
|
if err != nil {
|
|
println("err", err)
|
|
}
|
|
var tpl bytes.Buffer
|
|
for i, m := range parsedMetrics {
|
|
m.Help = strings.Join(strings.Split(m.Help, "\n"), ", ")
|
|
_ = m.BuildFQName() // ignore golint error
|
|
parsedMetrics[i] = m
|
|
}
|
|
sortedMetrics := byStabilityLevel(parsedMetrics)
|
|
data := templateData{
|
|
AlphaMetrics: sortedMetrics["ALPHA"],
|
|
BetaMetrics: sortedMetrics["BETA"],
|
|
StableMetrics: sortedMetrics["STABLE"],
|
|
GeneratedDate: time.Now(),
|
|
GeneratedVersion: fmt.Sprintf("%v.%v", major, parseMinor(minor)),
|
|
}
|
|
err = t.Execute(&tpl, data)
|
|
if err != nil {
|
|
println("err", err)
|
|
}
|
|
fmt.Print(tpl.String())
|
|
} else {
|
|
fmt.Fprintf(os.Stderr, "%s\n", err)
|
|
}
|
|
|
|
}
|
|
|
|
type metric struct {
|
|
Name string `yaml:"name" json:"name"`
|
|
Subsystem string `yaml:"subsystem,omitempty" json:"subsystem,omitempty"`
|
|
Namespace string `yaml:"namespace,omitempty" json:"namespace,omitempty"`
|
|
Help string `yaml:"help,omitempty" json:"help,omitempty"`
|
|
Type string `yaml:"type,omitempty" json:"type,omitempty"`
|
|
DeprecatedVersion string `yaml:"deprecatedVersion,omitempty" json:"deprecatedVersion,omitempty"`
|
|
StabilityLevel string `yaml:"stabilityLevel,omitempty" json:"stabilityLevel,omitempty"`
|
|
Labels []string `yaml:"labels,omitempty" json:"labels,omitempty"`
|
|
Buckets []float64 `yaml:"buckets,omitempty" json:"buckets,omitempty"`
|
|
Objectives map[float64]float64 `yaml:"objectives,omitempty" json:"objectives,omitempty"`
|
|
AgeBuckets uint32 `yaml:"ageBuckets,omitempty" json:"ageBuckets,omitempty"`
|
|
BufCap uint32 `yaml:"bufCap,omitempty" json:"bufCap,omitempty"`
|
|
MaxAge int64 `yaml:"maxAge,omitempty" json:"maxAge,omitempty"`
|
|
ConstLabels map[string]string `yaml:"constLabels,omitempty" json:"constLabels,omitempty"`
|
|
}
|
|
|
|
func (m metric) BuildFQName() string {
|
|
return metrics.BuildFQName(m.Namespace, m.Subsystem, m.Name)
|
|
}
|
|
|
|
type byFQName []metric
|
|
|
|
func (ms byFQName) Len() int { return len(ms) }
|
|
func (ms byFQName) Less(i, j int) bool {
|
|
if ms[i].StabilityLevel < ms[j].StabilityLevel {
|
|
return true
|
|
} else if ms[i].StabilityLevel > ms[j].StabilityLevel {
|
|
return false
|
|
}
|
|
return ms[i].BuildFQName() < ms[j].BuildFQName()
|
|
}
|
|
func (ms byFQName) Swap(i, j int) {
|
|
ms[i], ms[j] = ms[j], ms[i]
|
|
}
|
|
|
|
func byStabilityLevel(ms []metric) map[string][]metric {
|
|
res := map[string][]metric{}
|
|
for _, m := range ms {
|
|
if _, ok := res[m.StabilityLevel]; !ok {
|
|
res[m.StabilityLevel] = []metric{}
|
|
}
|
|
res[m.StabilityLevel] = append(res[m.StabilityLevel], m)
|
|
}
|
|
return res
|
|
}
|
|
|
|
func parseMinor(m string) string {
|
|
return strings.Trim(m, `+`)
|
|
}
|