The Prometheus monitoring system and time series database.
Find a file
Ganesh Vernekar c59ed492b2 Vertical query merging and compaction (#370)
* Vertical series iterator

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Select overlapped blocks first in compactor Plan()

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Added vertical compaction

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Code cleanup and comments

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Fix review comments

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Fix tests

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Add benchmark for compaction

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Perform vertical compaction only when blocks are overlapping.

Actions for vertical compaction:
* Sorting chunk metas
* Calling chunks.MergeOverlappingChunks on the chunks

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Benchmark for vertical compaction

* BenchmarkNormalCompaction => BenchmarkCompaction
* Moved the benchmark from db_test.go to compact_test.go

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Benchmark for query iterator and seek for non overlapping blocks

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Vertical query merge only for overlapping blocks

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Simplify logging in Compact(...)

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Updated CHANGELOG.md

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Calculate overlapping inside populateBlock

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* MinTime and MaxTime for BlockReader.

Using this to find overlapping blocks in populateBlock()

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Sort blocks w.r.t. MinTime in reload()

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Log about overlapping in LeveledCompactor.write() instead of returning bool

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Log about overlapping inside LeveledCompactor.populateBlock()

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Fix review comments

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Refactor createBlock to take optional []Series

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* review1

Signed-off-by: Krasi Georgiev <kgeorgie@redhat.com>

* Updated CHANGELOG and minor nits

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* nits

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Updated CHANGELOG

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Refactor iterator and seek benchmarks for Querier.

Also has as overlapping blocks.

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Additional test case

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* genSeries takes optional labels. Updated BenchmarkQueryIterator and BenchmarkQuerySeek.

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Split genSeries into genSeries and populateSeries

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Check error in benchmark

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Fix review comments

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* Warn about overlapping blocks in reload()

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>
2019-02-14 14:29:41 +01:00
chunkenc Remove pointer indirection on chunk bstream (#499) 2019-02-13 23:41:12 +01:00
chunks Vertical query merging and compaction (#370) 2019-02-14 14:29:41 +01:00
cmd/tsdb Merge branch 'master' into update-makefile-common 2019-01-22 10:47:31 +01:00
docs/format update labels count, chunks count 2019-02-06 10:00:18 +08:00
fileutil Update Makefile.common 2019-01-04 16:08:43 +01:00
index Update encoding_helpers.go (len of be64 should be 8) (#521) 2019-02-13 11:04:21 +02:00
labels fix statick check errors (#475) 2019-01-02 19:48:42 +03:00
test index: simplify checksum validation 2017-11-09 15:58:36 +00:00
testdata Add repair test 2018-02-09 13:43:42 +01:00
testutil Dont store stones in head, delete samples directly 2019-01-08 22:38:41 +05:30
tsdbutil Add license headers to missing files (#447) 2018-11-06 20:19:42 +02:00
wal clarify which segments are deleted when we find a corrupted segment (#522) 2019-02-14 05:44:19 +02:00
.gitignore Add default benchmark output dir to .gitignore 2018-01-14 11:07:52 +00:00
.travis.yml fix statick check errors (#475) 2019-01-02 19:48:42 +03:00
block.go Vertical query merging and compaction (#370) 2019-02-14 14:29:41 +01:00
block_test.go Vertical query merging and compaction (#370) 2019-02-14 14:29:41 +01:00
CHANGELOG.md Vertical query merging and compaction (#370) 2019-02-14 14:29:41 +01:00
checkpoint.go Delete temp checkpoint folder on error. (#415) 2019-01-07 11:43:33 +03:00
checkpoint_test.go Delete temp checkpoint folder on error. (#415) 2019-01-07 11:43:33 +03:00
compact.go Vertical query merging and compaction (#370) 2019-02-14 14:29:41 +01:00
compact_test.go Vertical query merging and compaction (#370) 2019-02-14 14:29:41 +01:00
db.go Vertical query merging and compaction (#370) 2019-02-14 14:29:41 +01:00
db_test.go Vertical query merging and compaction (#370) 2019-02-14 14:29:41 +01:00
encoding_helpers.go Remove more unused code 2019-01-07 14:45:17 +01:00
go.mod Use Go modules (#454) 2018-11-28 11:39:56 +01:00
go.sum Use Go modules (#454) 2018-11-28 11:39:56 +01:00
head.go Vertical query merging and compaction (#370) 2019-02-14 14:29:41 +01:00
head_bench_test.go Move series fetches out of inner loop of SortedPostings. (#485) 2019-01-03 10:35:10 +00:00
head_test.go Vertical query merging and compaction (#370) 2019-02-14 14:29:41 +01:00
LICENSE Add license file 2017-04-10 21:02:42 +02:00
MAINTAINERS.md add maintainers file (#404) 2018-10-15 14:32:00 +03:00
Makefile fix statick check errors (#475) 2019-01-02 19:48:42 +03:00
Makefile.common Update Makefile.common 2019-02-07 15:06:10 +01:00
mocks_test.go Vertical query merging and compaction (#370) 2019-02-14 14:29:41 +01:00
querier.go Vertical query merging and compaction (#370) 2019-02-14 14:29:41 +01:00
querier_test.go Vertical query merging and compaction (#370) 2019-02-14 14:29:41 +01:00
README.md comments about the 120samples const and link to Gorilla papers. (#423) 2018-10-23 13:43:06 +03:00
record.go fix lint errors (#439) 2018-11-14 18:40:01 +02:00
record_test.go Add checkpointing of WAL segments 2018-07-19 07:24:40 -04:00
repair.go use a global indexFilename constant 2019-01-29 10:32:32 +02:00
repair_test.go use a global indexFilename constant 2019-01-29 10:32:32 +02:00
tombstones.go Added storage size based retention method and new metrics (#343) 2019-01-16 13:03:52 +03:00
tombstones_test.go Merge branch 'master' into update-makefile-common 2019-01-22 10:47:31 +01:00
wal.go fix statick check errors (#475) 2019-01-02 19:48:42 +03:00
wal_test.go fix statick check errors (#475) 2019-01-02 19:48:42 +03:00

TSDB Build Status

GoDoc Go Report Card

This repository contains the Prometheus storage layer that is used in its 2.x releases.

A writeup of its design can be found here.

Based on the Gorilla TSDB white papers.

Video: Storing 16 Bytes at Scale from PromCon 2017.

See also the format documentation.