prometheus/tsdb
Bryan Boreham 4ced6d5f40 compactor: avoid memory blow-up with stringlabels
When compiled with `-tags stringlabels`, the names and values point into
a larger block of memory containing all labels. Garbage-collection
considers the entire block "live" if you point to a part of it, so the
map ends up retaining all labels for (nearly) all series.

Cloning the string value avoids this problem, and we check first if the
value is already in the map. Since the clone is more expensive, only do
it when built with `-tags stringlabels`.

Signed-off-by: Bryan Boreham <bjboreham@gmail.com>
2023-07-29 10:20:25 +01:00
..
agent Add Zstandard compression option for wlog (#11666) 2023-07-11 14:57:57 +02:00
chunkenc Fix errors from merge 2023-05-23 01:10:09 +08:00
chunks Fix race condition in ChunkDiskMapper.Truncate() (#12500) 2023-07-04 15:01:02 +00:00
docs Merge branch 'main' into sparsehistogram 2022-08-10 17:54:37 +02:00
encoding Merge 'main' into sparsehistogram 2022-10-05 22:14:49 +02:00
errors Fix context.Canceled wrapping in compaction 2023-03-23 11:41:28 +01:00
fileutil Update go to 1.19, set min version to 1.18 (#11279) 2022-09-07 11:30:48 +02:00
goversion lint: Adjust to the lint warnings raised by current versions of golint-ci 2023-04-19 17:10:10 +02:00
hashcache Merge remote-tracking branch 'upstream/main' into merge-upstream 2021-11-18 15:48:40 +01:00
index Merge remote-tracking branch 'upstream/main' 2023-07-19 21:40:27 +08:00
record tsdb: Support native histograms in snapshot on shutdown (#12258) 2023-07-05 11:44:13 +02:00
testdata tsdb: Delete blocks atomically; Remove tmp blocks on start; Added test. (#7772) 2020-08-11 06:56:08 +01:00
tombstones Merge remote-tracking branch 'upstream/main' 2023-05-23 00:20:36 +08:00
tsdbutil Fix populateWithDelChunkSeriesIterator and gauge histograms (#12330) 2023-05-19 10:24:06 +02:00
wlog Merge remote-tracking branch 'upstream/main' 2023-07-19 21:40:27 +08:00
.gitignore Moving tsdb into its own subdirectory 2019-08-13 13:58:49 +05:30
addsymbol.go compactor: avoid memory blow-up with stringlabels 2023-07-29 10:20:25 +01:00
addsymbol_stringlabels.go compactor: avoid memory blow-up with stringlabels 2023-07-29 10:20:25 +01:00
async_block_writer.go Fix bug in populateBlock when it could return with some asyncBlockWriter still running. 2023-01-09 17:15:45 +01:00
block.go Allow to configure compacted blocks postings for matchers cache 2023-03-22 06:40:11 +01:00
block_test.go Merge remote-tracking branch 'upstream/main' 2023-04-26 21:25:21 +08:00
blockwriter.go Merge remote-tracking branch 'upstream/main' 2022-11-23 01:39:23 +08:00
blockwriter_test.go Name float values as "floats", not as "values" 2023-04-13 19:25:24 +02:00
CHANGELOG.md Rename default branch to main 2021-02-22 20:28:02 +01:00
compact.go Merge remote-tracking branch 'upstream/main' 2023-07-19 21:40:27 +08:00
compact_test.go Merge remote-tracking branch 'upstream/main' 2023-07-19 21:40:27 +08:00
db.go Merge remote-tracking branch 'upstream/main' 2023-07-19 21:40:27 +08:00
db_test.go Merge remote-tracking branch 'upstream/main' 2023-07-19 21:40:27 +08:00
example_test.go storage: allow re-use of iterators 2022-12-15 18:32:45 +00:00
exemplar.go ci(lint): enable predeclared linter 2023-07-04 13:38:31 +00:00
exemplar_test.go tsdb: in tests use labels.FromStrings 2022-09-09 13:34:49 +02:00
head.go Merge remote-tracking branch 'upstream/main' 2023-07-19 21:40:27 +08:00
head_append.go Also pass chunkOpts into appendPreprocessor 2023-07-04 15:01:01 +00:00
head_append_test.go Merge pull request #29 from grafana/add-jitter-to-chunk-end 2021-11-16 11:05:07 +01:00
head_bench_test.go Add out-of-order sample support to the TSDB (#11075) 2022-09-20 22:35:50 +05:30
head_read.go Merge remote-tracking branch 'upstream/main' 2023-07-19 21:40:27 +08:00
head_read_test.go Fix merge conflicts 2022-10-11 22:53:37 +05:30
head_test.go Merge remote-tracking branch 'upstream/main' 2023-07-19 21:40:27 +08:00
head_wal.go Merge remote-tracking branch 'upstream/main' 2023-07-19 21:40:27 +08:00
isolation.go ci(lint): enable predeclared linter 2023-07-04 13:38:31 +00:00
isolation_test.go tsdb: turn off transaction isolation for head compaction (#11317) 2022-09-27 19:31:23 +05:30
mocks_test.go Move packages out of deprecated pkg directory 2021-11-09 08:03:10 +01:00
ooo_head.go Name float values as "floats", not as "values" 2023-04-13 19:25:24 +02:00
ooo_head_read.go Merge remote-tracking branch 'upstream/main' 2023-07-19 21:40:27 +08:00
ooo_head_read_test.go Add Zstandard compression option for wlog (#11666) 2023-07-11 14:57:57 +02:00
ooo_head_test.go Name float values as "floats", not as "values" 2023-04-13 19:25:24 +02:00
postings_for_matchers_cache.go Allow forcing usage of PostingsForMatchersCache 2022-12-28 13:44:10 +01:00
postings_for_matchers_cache_test.go Fix linter errors in Grafana additions 2023-04-28 16:32:42 +02:00
querier.go Optimize labelValuesWithMatchers to fetch label values from selected series (#518) 2023-07-27 11:44:29 +02:00
querier_bench_test.go Optimize labelValuesWithMatchers to fetch label values from selected series (#518) 2023-07-27 11:44:29 +02:00
querier_test.go Optimize labelValuesWithMatchers to fetch label values from selected series (#518) 2023-07-27 11:44:29 +02:00
README.md Fixed broken link in tsdb README.md 2022-10-07 16:20:20 +00:00
repair.go refactor: move from io/ioutil to io and os packages (#10528) 2022-04-27 11:24:36 +02:00
repair_test.go Simplify IndexReader.Series interface 2022-12-19 15:22:09 +00:00
symbols_batch.go compactor: avoid memory blow-up with stringlabels 2023-07-29 10:20:25 +01:00
symbols_batch_test.go Introduced some options for compactor concurrency (#66) 2021-12-02 10:34:52 +01:00
tsdbblockutil.go Support FloatHistogram in TSDB (#11522) 2022-12-28 14:25:07 +05:30
wal.go Add Zstandard compression option for wlog (#11666) 2023-07-11 14:57:57 +02:00
wal_test.go Add Zstandard compression option for wlog (#11666) 2023-07-11 14:57:57 +02:00

TSDB

GoPkg

This directory contains the Prometheus TSDB (Time Series DataBase) library, which handles storage and querying of all Prometheus v2 data.

Documentation

External resources

A series of blog posts explaining different components of TSDB: