Documentation ¶
Index ¶
- Variables
- func BucketQuantile(q float64, buckets Buckets) (float64, bool, bool)
- func FindMinMaxTime(s *parser.EvalStmt) (int64, int64)
- func HistogramFraction(lower, upper float64, h *histogram.FloatHistogram) float64
- func HistogramQuantile(q float64, h *histogram.FloatHistogram) float64
- func NewHistogramStatsIterator(it chunkenc.Iterator) chunkenc.Iterator
- func NewOriginContext(ctx context.Context, data map[string]interface{}) context.Context
- func PreprocessExpr(expr parser.Expr, start, end time.Time) parser.Expr
- type ActiveQueryTracker
- type Bucket
- type Buckets
- type Engine
- func (ng *Engine) Close() error
- func (ng *Engine) NewInstantQuery(ctx context.Context, q storage.Queryable, opts QueryOpts, qs string, ...) (Query, error)
- func (ng *Engine) NewRangeQuery(ctx context.Context, q storage.Queryable, opts QueryOpts, qs string, ...) (Query, error)
- func (ng *Engine) NewTestQuery(f func(context.Context) error) Query
- func (ng *Engine) SetQueryLogger(l QueryLogger)
- type EngineOpts
- type Entry
- type ErrQueryCanceled
- type ErrQueryTimeout
- type ErrStorage
- type ErrTooManySamples
- type EvalNodeHelper
- type EvalSeriesHelper
- type FPoint
- type FunctionCall
- type HPoint
- type HashRatioSampler
- type Matrix
- type PrometheusQueryOpts
- type Query
- type QueryEngine
- type QueryLogger
- type QueryOpts
- type QueryOrigin
- type QueryTracker
- type RatioSampler
- type Result
- type Sample
- type Scalar
- type Series
- type StorageSeries
- type String
- type Vector
Constants ¶
This section is empty.
Variables ¶
var ( ErrValidationAtModifierDisabled = errors.New("@ modifier is disabled") ErrValidationNegativeOffsetDisabled = errors.New("negative offset is disabled") )
var AtModifierUnsafeFunctions = map[string]struct{}{
"days_in_month": {}, "day_of_month": {}, "day_of_week": {}, "day_of_year": {},
"hour": {}, "minute": {}, "month": {}, "year": {},
"predict_linear": {}, "time": {},
"timestamp": {},
}
AtModifierUnsafeFunctions are the functions whose result can vary if evaluation time is changed when the arguments are step invariant. It also includes functions that use the timestamps of the passed instant vector argument to calculate a result since that can also change with change in eval time.
var FunctionCalls = map[string]FunctionCall{ "abs": funcAbs, "absent": funcAbsent, "absent_over_time": funcAbsentOverTime, "acos": funcAcos, "acosh": funcAcosh, "asin": funcAsin, "asinh": funcAsinh, "atan": funcAtan, "atanh": funcAtanh, "avg_over_time": funcAvgOverTime, "ceil": funcCeil, "changes": funcChanges, "clamp": funcClamp, "clamp_max": funcClampMax, "clamp_min": funcClampMin, "cos": funcCos, "cosh": funcCosh, "count_over_time": funcCountOverTime, "days_in_month": funcDaysInMonth, "day_of_month": funcDayOfMonth, "day_of_week": funcDayOfWeek, "day_of_year": funcDayOfYear, "deg": funcDeg, "delta": funcDelta, "deriv": funcDeriv, "exp": funcExp, "floor": funcFloor, "histogram_avg": funcHistogramAvg, "histogram_count": funcHistogramCount, "histogram_fraction": funcHistogramFraction, "histogram_quantile": funcHistogramQuantile, "histogram_sum": funcHistogramSum, "histogram_stddev": funcHistogramStdDev, "histogram_stdvar": funcHistogramStdVar, "double_exponential_smoothing": funcDoubleExponentialSmoothing, "hour": funcHour, "idelta": funcIdelta, "increase": funcIncrease, "info": nil, "irate": funcIrate, "label_replace": nil, "label_join": nil, "ln": funcLn, "log10": funcLog10, "log2": funcLog2, "last_over_time": funcLastOverTime, "mad_over_time": funcMadOverTime, "max_over_time": funcMaxOverTime, "min_over_time": funcMinOverTime, "minute": funcMinute, "month": funcMonth, "pi": funcPi, "predict_linear": funcPredictLinear, "present_over_time": funcPresentOverTime, "quantile_over_time": funcQuantileOverTime, "rad": funcRad, "rate": funcRate, "resets": funcResets, "round": funcRound, "scalar": funcScalar, "sgn": funcSgn, "sin": funcSin, "sinh": funcSinh, "sort": funcSort, "sort_desc": funcSortDesc, "sort_by_label": funcSortByLabel, "sort_by_label_desc": funcSortByLabelDesc, "sqrt": funcSqrt, "stddev_over_time": funcStddevOverTime, "stdvar_over_time": funcStdvarOverTime, "sum_over_time": funcSumOverTime, "tan": funcTan, "tanh": funcTanh, "time": funcTime, "timestamp": funcTimestamp, "vector": funcVector, "year": funcYear, }
FunctionCalls is a list of all functions supported by PromQL, including their types.
Functions ¶
func BucketQuantile ¶ added in v0.301.0
BucketQuantile calculates the quantile 'q' based on the given buckets. The buckets will be sorted by upperBound by this function (i.e. no sorting needed before calling this function). The quantile value is interpolated assuming a linear distribution within a bucket. However, if the quantile falls into the highest bucket, the upper bound of the 2nd highest bucket is returned. A natural lower bound of 0 is assumed if the upper bound of the lowest bucket is greater 0. In that case, interpolation in the lowest bucket happens linearly between 0 and the upper bound of the lowest bucket. However, if the lowest bucket has an upper bound less or equal 0, this upper bound is returned if the quantile falls into the lowest bucket.
There are a number of special cases (once we have a way to report errors happening during evaluations of AST functions, we should report those explicitly):
If 'buckets' has 0 observations, NaN is returned.
If 'buckets' has fewer than 2 elements, NaN is returned.
If the highest bucket is not +Inf, NaN is returned.
If q==NaN, NaN is returned.
If q<0, -Inf is returned.
If q>1, +Inf is returned.
We also return a bool to indicate if monotonicity needed to be forced, and another bool to indicate if small differences between buckets (that are likely artifacts of floating point precision issues) have been ignored.
Generically speaking, BucketQuantile is for calculating the histogram_quantile() of classic histograms. See also: HistogramQuantile for native histograms.
BucketQuantile is exported as a useful quantile function over a set of given buckets. It may be used by other PromQL engine implementations.
func FindMinMaxTime ¶ added in v0.49.0
FindMinMaxTime returns the time in milliseconds of the earliest and latest point in time the statement will try to process. This takes into account offsets, @ modifiers, and range selectors. If the statement does not select series, then FindMinMaxTime returns (0, 0).
func HistogramFraction ¶ added in v0.301.0
func HistogramFraction(lower, upper float64, h *histogram.FloatHistogram) float64
HistogramFraction calculates the fraction of observations between the provided lower and upper bounds, based on the provided histogram.
HistogramFraction is in a certain way the inverse of histogramQuantile. If HistogramQuantile(0.9, h) returns 123.4, then HistogramFraction(-Inf, 123.4, h) returns 0.9.
The same notes with regard to interpolation and assumptions about the zero bucket boundaries apply as for histogramQuantile.
Whether either boundary is inclusive or exclusive doesn’t actually matter as long as interpolation has to be performed anyway. In the case of a boundary coinciding with a bucket boundary, the inclusive or exclusive nature of the boundary determines the exact behavior of the threshold. With the current implementation, that means that lower is exclusive for positive values and inclusive for negative values, while upper is inclusive for positive values and exclusive for negative values.
Special cases:
If the histogram has 0 observations, NaN is returned.
Use a lower bound of -Inf to get the fraction of all observations below the upper bound.
Use an upper bound of +Inf to get the fraction of all observations above the lower bound.
If lower or upper is NaN, NaN is returned.
If lower >= upper and the histogram has at least 1 observation, zero is returned.
HistogramFraction is exported as it may be used by other PromQL engine implementations.
func HistogramQuantile ¶ added in v0.301.0
func HistogramQuantile(q float64, h *histogram.FloatHistogram) float64
HistogramQuantile calculates the quantile 'q' based on the given histogram.
For custom buckets, the result is interpolated linearly, i.e. it is assumed the observations are uniformly distributed within each bucket. (This is a quite blunt assumption, but it is consistent with the interpolation method used for classic histograms so far.)
For exponential buckets, the interpolation is done under the assumption that the samples within each bucket are distributed in a way that they would uniformly populate the buckets in a hypothetical histogram with higher resolution. For example, if the rank calculation suggests that the requested quantile is right in the middle of the population of the (1,2] bucket, we assume the quantile would be right at the bucket boundary between the two buckets the (1,2] bucket would be divided into if the histogram had double the resolution, which is 2**2**-1 = 1.4142... We call this exponential interpolation.
However, for a quantile that ends up in the zero bucket, this method isn't very helpful (because there is an infinite number of buckets close to zero, so we would have to assume zero as the result). Therefore, we return to linear interpolation in the zero bucket.
A natural lower bound of 0 is assumed if the histogram has only positive buckets. Likewise, a natural upper bound of 0 is assumed if the histogram has only negative buckets.
There are a number of special cases:
If the histogram has 0 observations, NaN is returned.
If q<0, -Inf is returned.
If q>1, +Inf is returned.
If q is NaN, NaN is returned.
HistogramQuantile is for calculating the histogram_quantile() of native histograms. See also: BucketQuantile for classic histograms.
HistogramQuantile is exported as it may be used by other PromQL engine implementations.
func NewHistogramStatsIterator ¶ added in v0.54.0
NewHistogramStatsIterator creates an iterator which returns histogram objects which have only their sum and count values populated. The iterator handles counter reset detection internally and sets the counter reset hint accordingly in each returned histogram objects.
func NewOriginContext ¶
NewOriginContext returns a new context with data about the origin attached.
Types ¶
type ActiveQueryTracker ¶
type ActiveQueryTracker struct {
// contains filtered or unexported fields
}
func NewActiveQueryTracker ¶
func NewActiveQueryTracker(localStoragePath string, maxConcurrent int, logger *slog.Logger) *ActiveQueryTracker
func (*ActiveQueryTracker) Close ¶ added in v0.46.0
func (tracker *ActiveQueryTracker) Close() error
Close closes tracker.
func (ActiveQueryTracker) Delete ¶
func (tracker ActiveQueryTracker) Delete(insertIndex int)
func (ActiveQueryTracker) GetMaxConcurrent ¶
func (tracker ActiveQueryTracker) GetMaxConcurrent() int
type Bucket ¶ added in v0.301.0
Bucket represents a bucket of a classic histogram. It is used internally by the promql package, but it is nevertheless exported for potential use in other PromQL engines.
type Engine ¶
type Engine struct {
// contains filtered or unexported fields
}
Engine handles the lifetime of queries from beginning to end. It is connected to a querier.
func (*Engine) NewInstantQuery ¶
func (ng *Engine) NewInstantQuery(ctx context.Context, q storage.Queryable, opts QueryOpts, qs string, ts time.Time) (Query, error)
NewInstantQuery returns an evaluation query for the given expression at the given time.
func (*Engine) NewRangeQuery ¶
func (ng *Engine) NewRangeQuery(ctx context.Context, q storage.Queryable, opts QueryOpts, qs string, start, end time.Time, interval time.Duration) (Query, error)
NewRangeQuery returns an evaluation query for the given time range and with the resolution set by the interval.
func (*Engine) NewTestQuery ¶ added in v0.53.0
NewTestQuery injects special behaviour into Query for testing.
func (*Engine) SetQueryLogger ¶
func (ng *Engine) SetQueryLogger(l QueryLogger)
SetQueryLogger sets the query logger.
type EngineOpts ¶
type EngineOpts struct { Logger *slog.Logger Reg prometheus.Registerer MaxSamples int Timeout time.Duration ActiveQueryTracker QueryTracker // LookbackDelta determines the time since the last sample after which a time // series is considered stale. LookbackDelta time.Duration // NoStepSubqueryIntervalFn is the default evaluation interval of // a subquery in milliseconds if no step in range vector was specified `[30m:<step>]`. NoStepSubqueryIntervalFn func(rangeMillis int64) int64 // EnableAtModifier if true enables @ modifier. Disabled otherwise. This // is supposed to be enabled for regular PromQL (as of Prometheus v2.33) // but the option to disable it is still provided here for those using // the Engine outside of Prometheus. EnableAtModifier bool // EnableNegativeOffset if true enables negative (-) offset // values. Disabled otherwise. This is supposed to be enabled for // regular PromQL (as of Prometheus v2.33) but the option to disable it // is still provided here for those using the Engine outside of // Prometheus. EnableNegativeOffset bool // EnablePerStepStats if true allows for per-step stats to be computed on request. Disabled otherwise. EnablePerStepStats bool // EnableDelayedNameRemoval delays the removal of the __name__ label to the last step of the query evaluation. // This is useful in certain scenarios where the __name__ label must be preserved or where applying a // regex-matcher to the __name__ label may otherwise lead to duplicate labelset errors. EnableDelayedNameRemoval bool }
EngineOpts contains configuration options used when creating a new Engine.
type ErrQueryCanceled ¶
type ErrQueryCanceled string
ErrQueryCanceled is returned if a query was canceled during processing.
func (ErrQueryCanceled) Error ¶
func (e ErrQueryCanceled) Error() string
type ErrQueryTimeout ¶
type ErrQueryTimeout string
ErrQueryTimeout is returned if a query timed out during processing.
func (ErrQueryTimeout) Error ¶
func (e ErrQueryTimeout) Error() string
type ErrStorage ¶
type ErrStorage struct{ Err error }
ErrStorage is returned if an error was encountered in the storage layer during query handling.
func (ErrStorage) Error ¶
func (e ErrStorage) Error() string
type ErrTooManySamples ¶
type ErrTooManySamples string
ErrTooManySamples is returned if a query would load more than the maximum allowed samples into memory.
func (ErrTooManySamples) Error ¶
func (e ErrTooManySamples) Error() string
type EvalNodeHelper ¶
type EvalNodeHelper struct { // Evaluation timestamp. Ts int64 // Vector that can be used for output. Out Vector // contains filtered or unexported fields }
EvalNodeHelper stores extra information and caches for evaluating a single node across steps.
type EvalSeriesHelper ¶
type EvalSeriesHelper struct {
// contains filtered or unexported fields
}
EvalSeriesHelper stores extra information about a series.
type FPoint ¶ added in v0.44.0
FPoint represents a single float data point for a given timestamp.
func (FPoint) MarshalJSON ¶ added in v0.44.0
MarshalJSON implements json.Marshaler.
JSON marshaling is only needed for the HTTP API. Since FPoint is such a frequently marshaled type, it gets an optimized treatment directly in web/api/v1/api.go. Therefore, this method is unused within Prometheus. It is still provided here as convenience for debugging and for other users of this code. Also note that the different marshaling implementations might lead to slightly different results in terms of formatting and rounding of the timestamp.
type FunctionCall ¶
type FunctionCall func(vals []parser.Value, args parser.Expressions, enh *EvalNodeHelper) (Vector, annotations.Annotations)
FunctionCall is the type of a PromQL function implementation
vals is a list of the evaluated arguments for the function call.
For range vectors it will be a Matrix with one series, instant vectors a Vector, scalars a Vector with one series whose value is the scalar value,and nil for strings.
args are the original arguments to the function, where you can access matrixSelectors, vectorSelectors, and StringLiterals.
enh.Out is a pre-allocated empty vector that you may use to accumulate output before returning it. The vectors in vals should not be returned.a
Range vector functions need only return a vector with the right value, the metric and timestamp are not needed.
Instant vector functions need only return a vector with the right values and metrics, the timestamp are not needed.
Scalar results should be returned as the value of a sample in a Vector.
type HPoint ¶ added in v0.44.0
type HPoint struct { T int64 H *histogram.FloatHistogram }
HPoint represents a single histogram data point for a given timestamp. H must never be nil.
func (HPoint) MarshalJSON ¶ added in v0.44.0
MarshalJSON implements json.Marshaler.
JSON marshaling is only needed for the HTTP API. Since HPoint is such a frequently marshaled type, it gets an optimized treatment directly in web/api/v1/api.go. Therefore, this method is unused within Prometheus. It is still provided here as convenience for debugging and for other users of this code. Also note that the different marshaling implementations might lead to slightly different results in terms of formatting and rounding of the timestamp.
type HashRatioSampler ¶ added in v0.54.0
type HashRatioSampler struct{}
HashRatioSampler uses Hash(labels.String()) / maxUint64 as a "deterministic" value in [0.0, 1.0].
func NewHashRatioSampler ¶ added in v0.54.0
func NewHashRatioSampler() *HashRatioSampler
func (*HashRatioSampler) AddRatioSample ¶ added in v0.54.0
func (s *HashRatioSampler) AddRatioSample(ratioLimit float64, sample *Sample) bool
type Matrix ¶
type Matrix []Series
Matrix is a slice of Series that implements sort.Interface and has a String method.
func (Matrix) ContainsSameLabelset ¶
ContainsSameLabelset checks if a matrix has samples with the same labelset. Such a behavior is semantically undefined. https://github.com/prometheus/prometheus/issues/4562
func (Matrix) TotalSamples ¶
TotalSamples returns the total number of samples in the series within a matrix. Float samples have a weight of 1 in this number, while histogram samples have a higher weight according to their size compared with the size of a float sample. See HPoint.size for details.
type PrometheusQueryOpts ¶ added in v0.46.0
type PrometheusQueryOpts struct {
// contains filtered or unexported fields
}
func (*PrometheusQueryOpts) EnablePerStepStats ¶ added in v0.46.0
func (p *PrometheusQueryOpts) EnablePerStepStats() bool
func (*PrometheusQueryOpts) LookbackDelta ¶ added in v0.46.0
func (p *PrometheusQueryOpts) LookbackDelta() time.Duration
type Query ¶
type Query interface { // Exec processes the query. Can only be called once. Exec(ctx context.Context) *Result // Close recovers memory used by the query result. Close() // Statement returns the parsed statement of the query. Statement() parser.Statement // Stats returns statistics about the lifetime of the query. Stats() *stats.Statistics // Cancel signals that a running query execution should be aborted. Cancel() // String returns the original query string. String() string }
A Query is derived from an a raw query string and can be run against an engine it is associated with.
type QueryEngine ¶ added in v0.52.0
type QueryEngine interface { NewInstantQuery(ctx context.Context, q storage.Queryable, opts QueryOpts, qs string, ts time.Time) (Query, error) NewRangeQuery(ctx context.Context, q storage.Queryable, opts QueryOpts, qs string, start, end time.Time, interval time.Duration) (Query, error) }
QueryEngine defines the interface for the *promql.Engine, so it can be replaced, wrapped or mocked.
type QueryLogger ¶
type QueryLogger interface { Log(context.Context, slog.Level, string, ...any) With(args ...any) Close() error }
QueryLogger is an interface that can be used to log all the queries logged by the engine.
type QueryOpts ¶
type QueryOrigin ¶
type QueryOrigin struct{}
type QueryTracker ¶
type QueryTracker interface { io.Closer // GetMaxConcurrent returns maximum number of concurrent queries that are allowed by this tracker. GetMaxConcurrent() int // Insert inserts query into query tracker. This call must block if maximum number of queries is already running. // If Insert doesn't return error then returned integer value should be used in subsequent Delete call. // Insert should return error if context is finished before query can proceed, and integer value returned in this case should be ignored by caller. Insert(ctx context.Context, query string) (int, error) // Delete removes query from activity tracker. InsertIndex is value returned by Insert call. Delete(insertIndex int) }
QueryTracker provides access to two features:
1) Tracking of active query. If PromQL engine crashes while executing any query, such query should be present in the tracker on restart, hence logged. After the logging on restart, the tracker gets emptied.
2) Enforcement of the maximum number of concurrent queries.
type RatioSampler ¶ added in v0.54.0
type RatioSampler interface { AddRatioSample(r float64, sample *Sample) bool // contains filtered or unexported methods }
RatioSampler allows unit-testing (previously: Randomizer).
type Result ¶
type Result struct { Err error Value parser.Value Warnings annotations.Annotations }
Result holds the resulting value of an execution or an error if any occurred.
func (*Result) Matrix ¶
Matrix returns a Matrix. An error is returned if the result was an error or the result value is not a Matrix.
type Sample ¶
type Sample struct { T int64 F float64 H *histogram.FloatHistogram Metric labels.Labels // DropName is used to indicate whether the __name__ label should be dropped // as part of the query evaluation. DropName bool }
Sample is a single sample belonging to a metric. It represents either a float sample or a histogram sample. If H is nil, it is a float sample. Otherwise, it is a histogram sample.
func (Sample) MarshalJSON ¶
MarshalJSON is mirrored in web/api/v1/api.go with jsoniter because FPoint and HPoint wouldn't be marshaled with jsoniter otherwise.
type Scalar ¶
Scalar is a data point that's explicitly not associated with a metric.
func (Scalar) MarshalJSON ¶
type Series ¶
type Series struct { Metric labels.Labels `json:"metric"` Floats []FPoint `json:"values,omitempty"` Histograms []HPoint `json:"histograms,omitempty"` // DropName is used to indicate whether the __name__ label should be dropped // as part of the query evaluation. DropName bool `json:"-"` }
Series is a stream of data points belonging to a metric.
type StorageSeries ¶
type StorageSeries struct {
// contains filtered or unexported fields
}
StorageSeries simulates promql.Series as storage.Series.
func NewStorageSeries ¶
func NewStorageSeries(series Series) *StorageSeries
NewStorageSeries returns a StorageSeries from a Series.
func (*StorageSeries) Iterator ¶
func (ss *StorageSeries) Iterator(it chunkenc.Iterator) chunkenc.Iterator
Iterator returns a new iterator of the data of the series. In case of multiple samples with the same timestamp, it returns the float samples first.
func (*StorageSeries) Labels ¶
func (ss *StorageSeries) Labels() labels.Labels
type Vector ¶
type Vector []Sample
Vector is basically only an alias for []Sample, but the contract is that in a Vector, all Samples have the same timestamp.
func (Vector) ContainsSameLabelset ¶
ContainsSameLabelset checks if a vector has samples with the same labelset Such a behavior is semantically undefined https://github.com/prometheus/prometheus/issues/4562
func (Vector) TotalSamples ¶ added in v0.49.0
TotalSamples returns the total number of samples in the series within a vector. Float samples have a weight of 1 in this number, while histogram samples have a higher weight according to their size compared with the size of a float sample. See HPoint.size for details.
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
Code generated by goyacc -l -o promql/parser/generated_parser.y.go promql/parser/generated_parser.y.
|
Code generated by goyacc -l -o promql/parser/generated_parser.y.go promql/parser/generated_parser.y. |
posrange
posrange is used to report a position in query strings for error and warning messages.
|
posrange is used to report a position in query strings for error and warning messages. |