prometheus/storage/remote/max_timestamp.go
machine424 caa71fb3c7 chore(storage/remote): collect maxTimestamp when value is 0 as well.
This change enables the PrometheusRemoteWriteBehind alert’s expression to be evaluated
even when the remote endpoint has never been reached. As a result, PrometheusRemoteWriteBehind
will fire to easily detect configuration mistakes (such as incorrect endpoint URLs) or
unrecoverable connectivity issues.

See https://github.com/prometheus/prometheus/issues/14350 for details.

Signed-off-by: machine424 <ayoubmrini424@gmail.com>
2024-07-11 16:43:58 +02:00

42 lines
1001 B
Go

// Copyright 2019 The Prometheus 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 remote
import (
"sync"
"github.com/prometheus/client_golang/prometheus"
)
type maxTimestamp struct {
mtx sync.Mutex
value float64
prometheus.Gauge
}
func (m *maxTimestamp) Set(value float64) {
m.mtx.Lock()
defer m.mtx.Unlock()
if value > m.value {
m.value = value
m.Gauge.Set(value)
}
}
func (m *maxTimestamp) Get() float64 {
m.mtx.Lock()
defer m.mtx.Unlock()
return m.value
}