Skip to content

Commit

Permalink
[query] Add lookback duration from query config
Browse files Browse the repository at this point in the history
  • Loading branch information
robskillington committed Nov 17, 2020
1 parent f5eea1e commit 4e0a26f
Show file tree
Hide file tree
Showing 4 changed files with 41 additions and 9 deletions.
2 changes: 2 additions & 0 deletions scripts/docker-integration-tests/prometheus/m3coordinator.yml
Original file line number Diff line number Diff line change
Expand Up @@ -23,3 +23,5 @@ query:
value: hidden
strip:
- restricted_metrics_type

lookbackDuration: 10m
20 changes: 20 additions & 0 deletions scripts/docker-integration-tests/prometheus/test.sh
Original file line number Diff line number Diff line change
Expand Up @@ -177,6 +177,25 @@ function test_prometheus_remote_write_map_tags {
retry_with_backoff prometheus_query_native
}

function test_query_lookback_applied {
# Note: this test depends on the config in m3coordinator.yml for this test
# and the following config value "lookbackDuration: 10m".
echo "Test lookback config respected"
now=$(date +"%s")
# Write into past less than the lookback duration.
eight_mins_ago=$(( now - 480 ))
prometheus_remote_write \
"lookback_test" $eight_mins_ago 42 \
true "Expected request to succeed" \
200 "Expected request to return status code 200" \
"unaggregated"

# Now query and ensure that the latest timestamp is within the last two steps
# from now.
ATTEMPTS=2 TIMEOUT=2 MAX_TIMEOUT=4 retry_with_backoff \
'[[ $(curl -s "0.0.0.0:7201/api/v1/query_range?query=lookback_test&step=15&start=$(expr $(date "+%s") - 600)&end=$(date "+%s")" | jq -r ".data.result[0].values[-1][0]") -gt $(expr $(date "+%s") - 30) ]]'
}

function test_query_limits_applied {
# Test the default series limit applied when directly querying
# coordinator (limit set to 100 in m3coordinator.yml)
Expand Down Expand Up @@ -373,6 +392,7 @@ test_prometheus_remote_write_empty_label_value_returns_400_status_code
test_prometheus_remote_write_duplicate_label_returns_400_status_code
test_prometheus_remote_write_too_old_returns_400_status_code
test_prometheus_remote_write_restrict_metrics_type
test_query_lookback_applied
test_query_limits_applied
test_query_restrict_metrics_type
test_prometheus_query_native_timeout
Expand Down
2 changes: 1 addition & 1 deletion src/cmd/services/m3query/config/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,7 @@ var (
ExtendedMetrics: &defaultMetricsExtendedMetricsType,
}

// 5m is the default lookback in Prometheus
// 5m is the default lookback in Prometheus.
defaultLookbackDuration = 5 * time.Minute

defaultCarbonIngesterAggregationType = aggregation.Mean
Expand Down
26 changes: 18 additions & 8 deletions src/query/server/query.go
Original file line number Diff line number Diff line change
Expand Up @@ -479,8 +479,12 @@ func Run(runOpts RunOptions) {
graphiteStorageOpts.RenderSeriesAllNaNs = cfg.Carbon.RenderSeriesAllNaNs
}

prometheusEngine := newPromQLEngine(cfg.Query, prometheusEngineRegistry,
prometheusEngine, err := newPromQLEngine(cfg, prometheusEngineRegistry,
instrumentOptions)
if err != nil {
logger.Fatal("unable to create PromQL engine", zap.Error(err))
}

handlerOptions, err := options.NewHandlerOptions(downsamplerAndWriter,
tagOptions, engine, prometheusEngine, m3dbClusters, clusterClient, cfg,
runOpts.DBConfig, fetchOptsBuilder, queryCtxOpts,
Expand Down Expand Up @@ -1154,18 +1158,24 @@ func newDownsamplerAndWriter(
}

func newPromQLEngine(
cfg config.QueryConfiguration,
cfg config.Configuration,
registry *extprom.Registry,
instrumentOpts instrument.Options,
) *prometheuspromql.Engine {
) (*prometheuspromql.Engine, error) {
lookbackDelta, err := cfg.LookbackDurationOrDefault()
if err != nil {
return nil, err
}

var (
kitLogger = kitlogzap.NewZapSugarLogger(instrumentOpts.Logger(), zapcore.InfoLevel)
opts = prometheuspromql.EngineOpts{
Logger: log.With(kitLogger, "component", "prometheus_engine"),
Reg: registry,
MaxSamples: cfg.Prometheus.MaxSamplesPerQueryOrDefault(),
Timeout: cfg.TimeoutOrDefault(),
Logger: log.With(kitLogger, "component", "prometheus_engine"),
Reg: registry,
MaxSamples: cfg.Query.Prometheus.MaxSamplesPerQueryOrDefault(),
Timeout: cfg.Query.TimeoutOrDefault(),
LookbackDelta: lookbackDelta,
}
)
return prometheuspromql.NewEngine(opts)
return prometheuspromql.NewEngine(opts), nil
}

0 comments on commit 4e0a26f

Please sign in to comment.