mirror of
https://github.com/prometheus/prometheus.git
synced 2025-01-11 13:57:36 -08:00
Decrement active_appenders metric when no samples added (#9230)
* Decrement active_appenders metric when no samples added Also add a test that the metric is incremented and decremented as expected with and without samples. Signed-off-by: Bryan Boreham <bjboreham@gmail.com> * Fix comment Signed-off-by: Ganesh Vernekar <ganeshvern@gmail.com> Co-authored-by: Ganesh Vernekar <ganeshvern@gmail.com>
This commit is contained in:
parent
87d909df4a
commit
2327236bb5
|
@ -85,6 +85,7 @@ func (a *initAppender) GetRef(lset labels.Labels) (uint64, labels.Labels) {
|
||||||
|
|
||||||
func (a *initAppender) Commit() error {
|
func (a *initAppender) Commit() error {
|
||||||
if a.app == nil {
|
if a.app == nil {
|
||||||
|
a.head.metrics.activeAppenders.Dec()
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
return a.app.Commit()
|
return a.app.Commit()
|
||||||
|
@ -92,6 +93,7 @@ func (a *initAppender) Commit() error {
|
||||||
|
|
||||||
func (a *initAppender) Rollback() error {
|
func (a *initAppender) Rollback() error {
|
||||||
if a.app == nil {
|
if a.app == nil {
|
||||||
|
a.head.metrics.activeAppenders.Dec()
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
return a.app.Rollback()
|
return a.app.Rollback()
|
||||||
|
|
|
@ -402,6 +402,39 @@ func TestHead_WALMultiRef(t *testing.T) {
|
||||||
}}, series)
|
}}, series)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestHead_ActiveAppenders(t *testing.T) {
|
||||||
|
head, _ := newTestHead(t, 1000, false)
|
||||||
|
defer head.Close()
|
||||||
|
|
||||||
|
require.NoError(t, head.Init(0))
|
||||||
|
|
||||||
|
// First rollback with no samples.
|
||||||
|
app := head.Appender(context.Background())
|
||||||
|
require.Equal(t, 1.0, prom_testutil.ToFloat64(head.metrics.activeAppenders))
|
||||||
|
require.NoError(t, app.Rollback())
|
||||||
|
require.Equal(t, 0.0, prom_testutil.ToFloat64(head.metrics.activeAppenders))
|
||||||
|
|
||||||
|
// Then commit with no samples.
|
||||||
|
app = head.Appender(context.Background())
|
||||||
|
require.NoError(t, app.Commit())
|
||||||
|
require.Equal(t, 0.0, prom_testutil.ToFloat64(head.metrics.activeAppenders))
|
||||||
|
|
||||||
|
// Now rollback with one sample.
|
||||||
|
app = head.Appender(context.Background())
|
||||||
|
_, err := app.Append(0, labels.FromStrings("foo", "bar"), 100, 1)
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Equal(t, 1.0, prom_testutil.ToFloat64(head.metrics.activeAppenders))
|
||||||
|
require.NoError(t, app.Rollback())
|
||||||
|
require.Equal(t, 0.0, prom_testutil.ToFloat64(head.metrics.activeAppenders))
|
||||||
|
|
||||||
|
// Now commit with one sample.
|
||||||
|
app = head.Appender(context.Background())
|
||||||
|
_, err = app.Append(0, labels.FromStrings("foo", "bar"), 100, 1)
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.NoError(t, app.Commit())
|
||||||
|
require.Equal(t, 0.0, prom_testutil.ToFloat64(head.metrics.activeAppenders))
|
||||||
|
}
|
||||||
|
|
||||||
func TestHead_UnknownWALRecord(t *testing.T) {
|
func TestHead_UnknownWALRecord(t *testing.T) {
|
||||||
head, w := newTestHead(t, 1000, false)
|
head, w := newTestHead(t, 1000, false)
|
||||||
w.Log([]byte{255, 42})
|
w.Log([]byte{255, 42})
|
||||||
|
|
Loading…
Reference in a new issue