mirror of
https://github.com/prometheus/prometheus.git
synced 2025-01-27 13:42:31 -08:00
Review improvements
This commit is contained in:
parent
8cdced3850
commit
9d8fbbe822
|
@ -313,7 +313,7 @@ func rangeValues(it chunkIterator, in metric.Interval) ([]model.SamplePair, erro
|
||||||
}
|
}
|
||||||
|
|
||||||
// addToOverflowChunk is a utility function that creates a new chunk as overflow
|
// addToOverflowChunk is a utility function that creates a new chunk as overflow
|
||||||
// chunk, addse the provided sample to it, and returns a chunk slice containing
|
// chunk, adds the provided sample to it, and returns a chunk slice containing
|
||||||
// the provided old chunk followed by the new overflow chunk.
|
// the provided old chunk followed by the new overflow chunk.
|
||||||
func addToOverflowChunk(c chunk, s model.SamplePair) ([]chunk, error) {
|
func addToOverflowChunk(c chunk, s model.SamplePair) ([]chunk, error) {
|
||||||
overflowChunks, err := newChunk().add(s)
|
overflowChunks, err := newChunk().add(s)
|
||||||
|
|
|
@ -26,9 +26,8 @@ import (
|
||||||
// Gorilla: A Fast, Scalable, In-Memory Time Series Database
|
// Gorilla: A Fast, Scalable, In-Memory Time Series Database
|
||||||
// T. Pelkonen et al., Facebook Inc.
|
// T. Pelkonen et al., Facebook Inc.
|
||||||
// http://www.vldb.org/pvldb/vol8/p1816-teller.pdf
|
// http://www.vldb.org/pvldb/vol8/p1816-teller.pdf
|
||||||
// Note that there are significant differences in detail, some of which due to
|
// Note that there are significant differences in detail, some due to the way
|
||||||
// the way Prometheus chunks work, some of which to optimize for the Prometheus
|
// Prometheus chunks work, others to optimize for the Prometheus use-case.
|
||||||
// use-case.
|
|
||||||
//
|
//
|
||||||
// Layout of a 1024 byte gorilla chunk (big endian, wherever it matters):
|
// Layout of a 1024 byte gorilla chunk (big endian, wherever it matters):
|
||||||
// - first time (int64): 8 bytes bit 0000-0063
|
// - first time (int64): 8 bytes bit 0000-0063
|
||||||
|
@ -391,12 +390,12 @@ func (c gorillaChunk) zeroDDTRepeats() (repeats uint64, offset uint16) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c gorillaChunk) setZeroDDTRepeats(repeats uint64, offset uint16) {
|
func (c gorillaChunk) setZeroDDTRepeats(repeats uint64, offset uint16) {
|
||||||
if repeats == 0 {
|
switch repeats {
|
||||||
|
case 0:
|
||||||
// Just clear the offset.
|
// Just clear the offset.
|
||||||
binary.BigEndian.PutUint16(c[gorillaCountOffsetBitOffset:], 0)
|
binary.BigEndian.PutUint16(c[gorillaCountOffsetBitOffset:], 0)
|
||||||
return
|
return
|
||||||
}
|
case 1:
|
||||||
if repeats == 1 {
|
|
||||||
// First time we set a repeat here, so set the offset. But only
|
// First time we set a repeat here, so set the offset. But only
|
||||||
// if we haven't reached the footer yet. (If that's the case, we
|
// if we haven't reached the footer yet. (If that's the case, we
|
||||||
// would overwrite ourselves below, and we don't need the offset
|
// would overwrite ourselves below, and we don't need the offset
|
||||||
|
@ -405,8 +404,7 @@ func (c gorillaChunk) setZeroDDTRepeats(repeats uint64, offset uint16) {
|
||||||
if offset+7 <= gorillaNextSampleBitOffsetThreshold {
|
if offset+7 <= gorillaNextSampleBitOffsetThreshold {
|
||||||
binary.BigEndian.PutUint16(c[gorillaCountOffsetBitOffset:], offset)
|
binary.BigEndian.PutUint16(c[gorillaCountOffsetBitOffset:], offset)
|
||||||
}
|
}
|
||||||
}
|
default:
|
||||||
if repeats > 1 {
|
|
||||||
// For a change, we are writing somewhere where we have written
|
// For a change, we are writing somewhere where we have written
|
||||||
// before. We need to clear the bits first.
|
// before. We need to clear the bits first.
|
||||||
posIn1stByte := offset % 8
|
posIn1stByte := offset % 8
|
||||||
|
|
Loading…
Reference in a new issue