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 2021 The Sigstore 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 api
import (
"time"
"github.com/prometheus/client_golang/prometheus"
"github.com/prometheus/client_golang/prometheus/promauto"
"sigs.k8s.io/release-utils/version"
)
var (
metricNewEntries = promauto.NewCounter(prometheus.CounterOpts{
Name: "rekor_new_entries",
Help: "The total number of new log entries",
})
metricPublishEvents = promauto.NewCounterVec(prometheus.CounterOpts{
Name: "rekor_publish_events",
Help: "The status of publishing events to Pub/Sub",
}, []string{"event", "content_type", "status"})
metricIndexStorageLatency = promauto.NewSummaryVec(prometheus.SummaryOpts{
Name: "rekor_index_storage_latency_summary",
Help: "Latency of backend index insertion by success/failure",
}, []string{"success"})
MetricLatency = promauto.NewHistogramVec(prometheus.HistogramOpts{
Name: "rekor_api_latency",
Help: "Api Latency on calls",
}, []string{"path", "code"})
MetricLatencySummary = promauto.NewSummaryVec(prometheus.SummaryOpts{
Name: "rekor_api_latency_summary",
Help: "Api Latency on calls",
}, []string{"path", "code"})
MetricRequestLatency = promauto.NewHistogramVec(prometheus.HistogramOpts{
Name: "rekor_latency_by_api",
Help: "Api Latency (in ns) by path and method",
Buckets: prometheus.ExponentialBucketsRange(
float64(time.Millisecond),
float64(4*time.Second),
10),
}, []string{"path", "method"})
MetricRequestCount = promauto.NewCounterVec(prometheus.CounterOpts{
Name: "rekor_qps_by_api",
Help: "Api QPS by path, method, and response code",
}, []string{"path", "method", "code"})
CheckpointPublishCount = promauto.NewCounterVec(prometheus.CounterOpts{
Name: "rekor_checkpoint_publish",
Help: "Checkpoint publishing by shard and code",
}, []string{"shard", "code"})
_ = promauto.NewGaugeFunc(
prometheus.GaugeOpts{
Namespace: "rekor",
Name: "build_info",
Help: "A metric with a constant '1' value labeled by version, revision, branch, and goversion from which rekor was built.",
ConstLabels: prometheus.Labels{
"version": version.GetVersionInfo().GitVersion,
"revision": version.GetVersionInfo().GitCommit,
"build_date": version.GetVersionInfo().BuildDate,
"goversion": version.GetVersionInfo().GoVersion,
},
},
func() float64 { return 1 },
)
)
|