mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-20 07:19:17 +01:00
app/vmselect: add -search.maxStatusRequestDuration
command-line flag for limiting the duration of requests to /api/v1/status/*
and /api/v1/series/count
This commit is contained in:
parent
2af39a96c5
commit
e7fdea5953
@ -610,7 +610,7 @@ var labelValuesDuration = metrics.NewSummary(`vm_request_duration_seconds{path="
|
|||||||
|
|
||||||
// LabelsCountHandler processes /api/v1/labels/count request.
|
// LabelsCountHandler processes /api/v1/labels/count request.
|
||||||
func LabelsCountHandler(startTime time.Time, w http.ResponseWriter, r *http.Request) error {
|
func LabelsCountHandler(startTime time.Time, w http.ResponseWriter, r *http.Request) error {
|
||||||
deadline := searchutils.GetDeadlineForQuery(r, startTime)
|
deadline := searchutils.GetDeadlineForStatusRequest(r, startTime)
|
||||||
labelEntries, err := netstorage.GetLabelEntries(deadline)
|
labelEntries, err := netstorage.GetLabelEntries(deadline)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf(`cannot obtain label entries: %w`, err)
|
return fmt.Errorf(`cannot obtain label entries: %w`, err)
|
||||||
@ -634,7 +634,7 @@ const secsPerDay = 3600 * 24
|
|||||||
//
|
//
|
||||||
// See https://prometheus.io/docs/prometheus/latest/querying/api/#tsdb-stats
|
// See https://prometheus.io/docs/prometheus/latest/querying/api/#tsdb-stats
|
||||||
func TSDBStatusHandler(startTime time.Time, w http.ResponseWriter, r *http.Request) error {
|
func TSDBStatusHandler(startTime time.Time, w http.ResponseWriter, r *http.Request) error {
|
||||||
deadline := searchutils.GetDeadlineForQuery(r, startTime)
|
deadline := searchutils.GetDeadlineForStatusRequest(r, startTime)
|
||||||
if err := r.ParseForm(); err != nil {
|
if err := r.ParseForm(); err != nil {
|
||||||
return fmt.Errorf("cannot parse form values: %w", err)
|
return fmt.Errorf("cannot parse form values: %w", err)
|
||||||
}
|
}
|
||||||
@ -810,7 +810,7 @@ var labelsDuration = metrics.NewSummary(`vm_request_duration_seconds{path="/api/
|
|||||||
|
|
||||||
// SeriesCountHandler processes /api/v1/series/count request.
|
// SeriesCountHandler processes /api/v1/series/count request.
|
||||||
func SeriesCountHandler(startTime time.Time, w http.ResponseWriter, r *http.Request) error {
|
func SeriesCountHandler(startTime time.Time, w http.ResponseWriter, r *http.Request) error {
|
||||||
deadline := searchutils.GetDeadlineForQuery(r, startTime)
|
deadline := searchutils.GetDeadlineForStatusRequest(r, startTime)
|
||||||
n, err := netstorage.GetSeriesCount(deadline)
|
n, err := netstorage.GetSeriesCount(deadline)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("cannot obtain series count: %w", err)
|
return fmt.Errorf("cannot obtain series count: %w", err)
|
||||||
|
@ -16,8 +16,9 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
maxExportDuration = flag.Duration("search.maxExportDuration", time.Hour*24*30, "The maximum duration for /api/v1/export call")
|
maxExportDuration = flag.Duration("search.maxExportDuration", time.Hour*24*30, "The maximum duration for /api/v1/export call")
|
||||||
maxQueryDuration = flag.Duration("search.maxQueryDuration", time.Second*30, "The maximum duration for query execution")
|
maxQueryDuration = flag.Duration("search.maxQueryDuration", time.Second*30, "The maximum duration for query execution")
|
||||||
|
maxStatusRequestDuration = flag.Duration("search.maxStatusRequestDuration", time.Minute*5, "The maximum duration for /api/v1/status/* requests")
|
||||||
)
|
)
|
||||||
|
|
||||||
func roundToSeconds(ms int64) int64 {
|
func roundToSeconds(ms int64) int64 {
|
||||||
@ -125,6 +126,12 @@ func GetDeadlineForQuery(r *http.Request, startTime time.Time) Deadline {
|
|||||||
return getDeadlineWithMaxDuration(r, startTime, dMax, "-search.maxQueryDuration")
|
return getDeadlineWithMaxDuration(r, startTime, dMax, "-search.maxQueryDuration")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetDeadlineForStatusRequest returns deadline for the given request to /api/v1/status/*.
|
||||||
|
func GetDeadlineForStatusRequest(r *http.Request, startTime time.Time) Deadline {
|
||||||
|
dMax := maxStatusRequestDuration.Milliseconds()
|
||||||
|
return getDeadlineWithMaxDuration(r, startTime, dMax, "-search.maxStatusRequestDuration")
|
||||||
|
}
|
||||||
|
|
||||||
// GetDeadlineForExport returns deadline for the given request to /api/v1/export.
|
// GetDeadlineForExport returns deadline for the given request to /api/v1/export.
|
||||||
func GetDeadlineForExport(r *http.Request, startTime time.Time) Deadline {
|
func GetDeadlineForExport(r *http.Request, startTime time.Time) Deadline {
|
||||||
dMax := maxExportDuration.Milliseconds()
|
dMax := maxExportDuration.Milliseconds()
|
||||||
|
Loading…
Reference in New Issue
Block a user