Merge pull request #64 from prometheus/dbref

Fix and test ref handling in DB appender
This commit is contained in:
Fabian Reinartz 2017-04-28 16:08:00 +02:00 committed by GitHub
commit cdfb604d89
2 changed files with 33 additions and 2 deletions

4
db.go
View File

@ -521,7 +521,7 @@ func (a *dbAppender) Add(lset labels.Labels, t int64, v float64) (uint64, error)
} }
a.samples++ a.samples++
// Store last byte of sequence number in 3rd byte of reference. // Store last byte of sequence number in 3rd byte of reference.
return ref | (uint64(h.meta.Sequence^0xff) << 40), nil return ref | (uint64(h.meta.Sequence&0xff) << 40), nil
} }
func (a *dbAppender) AddFast(ref uint64, t int64, v float64) error { func (a *dbAppender) AddFast(ref uint64, t int64, v float64) error {
@ -534,7 +534,7 @@ func (a *dbAppender) AddFast(ref uint64, t int64, v float64) error {
return err return err
} }
// If the last byte of the sequence does not add up, the reference is not valid. // If the last byte of the sequence does not add up, the reference is not valid.
if uint64(h.meta.Sequence^0xff) != gen { if uint64(h.meta.Sequence&0xff) != gen {
return ErrNotFound return ErrNotFound
} }
if err := h.app.AddFast(ref, t, v); err != nil { if err := h.app.AddFast(ref, t, v); err != nil {

View File

@ -98,3 +98,34 @@ func TestDataNotAvailableAfterRollback(t *testing.T) {
require.NoError(t, err) require.NoError(t, err)
require.Equal(t, seriesSet, map[string][]sample{}) require.Equal(t, seriesSet, map[string][]sample{})
} }
func TestDBAppenderAddRef(t *testing.T) {
tmpdir, _ := ioutil.TempDir("", "test")
defer os.RemoveAll(tmpdir)
db, err := Open(tmpdir, nil, nil, nil)
require.NoError(t, err)
defer db.Close()
app := db.Appender()
defer app.Rollback()
ref, err := app.Add(labels.FromStrings("a", "b"), 0, 0)
require.NoError(t, err)
// Head sequence number should be in 3rd MSB and be greater than 0.
gen := (ref << 16) >> 56
require.True(t, gen > 1)
// Reference must be valid to add another sample.
err = app.AddFast(ref, 1, 1)
require.NoError(t, err)
// AddFast for the same timestamp must fail if the generation in the reference
// doesn't add up.
refBad := ref | ((gen + 1) << 4)
err = app.AddFast(refBad, 1, 1)
require.Error(t, err)
require.Equal(t, 2, app.(*dbAppender).samples)
}