Refinery rules are described as a series of conditions. Each condition is composed from a combination of these named parameters:
Field
(orFields
)Operator
Value
Datatype
The Operator
is a required parameter, and controls which of the condition's other elements are required and which are optional.
The Field
parameter points to a specific named element in the trace data.
If a Field
is named within a span, then it exists
.
A specific Field
may or may not exist on any specific span in a trace.
It might not even exist within a trace at all.
When a Field
is absent in all spans within a trace, the associated rule does not apply to that trace.
A Field
is always a single string.
A Field
is always matched by exact comparison.
No transformations for case or punctuation are performed.
Conditions:
Field: http.route
Operator: =
Value: /health-check
Some Refinery configuration options introduce special fields that are added to telemetry.
For example, when AddCountsToRoot
is enabled, meta.span_count
is added to all root spans, and allows for the creation of rule conditions based on span counts.
In this meta.span_count
example, the Refinery rule applies to traces with more than 300 spans.
Conditions:
Field: "meta.span_count"
Operator: ">"
Value: 300
Datatype: int
For details about all supported special fields, check out our Refinery Telemetry documentation.
To handle specific scenarios when rules are evaluated before the arrival of root spans, Refinery introduces the concept of virtual fields. These fields provide metadata about traces that have timed out while waiting for their root span.
This example shows a rule that drops traces containing more than 1000 spans by using the virtual field ?.NUM_DESCENDANTS
.
Rules:
- Name: Drop any big traces
Drop: true
Conditions:
Field: "?.NUM_DESCENDANTS"
Operator: ">"
Value: 1000
Datatype: int
All virtual fields are prefixed with ?.
to distinguish them from normal fields.
Currently only one virtual field is supported.
?.NUM_DESCENDANTS
: the current number of child elements contained within a trace.
The Fields
parameter allows a single rule to apply to the first match among multiple field names.
It is typically used when telemetry field names are being changed.
It is exactly equivalent to Field
, except that it must be expressed as an array of strings instead of a single value.
The array defines a sequences of Field
names that are checked in order for each span being considered.
The first field that exists
on any given span is used for the condition.
This example shows how one might write a rule designed to cope with an expected name change of a key field.
Conditions:
Fields:
- http.status
- http.request.status
Operator: =
Value: 200
Datatype: int
Fields can contain a span selection prefix. Today, the only prefix supported is root
.
This prefix causes the root span to be searched for the specified field, rather than the span being evaluated.
Rules:
- Name: limit by root span context
Conditions:
Field: "root.http.status"
Operator: =
Value: "500"
Datatype: string
The Operator
parameter controls how rules are evaluated.
Because YAML treats certain characters like less-than (<
) specially, it is good practice to always enclose the basic comparison operators in single quotes (like '<'
).
The Operator
may be one of the following:
Basic comparison -- equals
.
The result is true if the value of the named Field
is equal to the Value
specified.
See Datatype
for how different datatypes are handled.
Basic comparison -- not equals
.
The result is true if the value of the named Field
is not equal to the Value
specified.
See Datatype
for how different datatypes are handled.
For most cases, use '!='
in a rule with a scope of "span".
WARNING: Rules can have Scope: trace
or Scope: span
; '!='
used with Scope: trace
will be true if any single span in the entire trace matches the negative condition.
This is almost never desired behavior.
Basic comparison -- less than
.
The result is true if the value of the named Field
is less than the Value
specified.
See Datatype
for how different datatypes are handled.
Basic comparison -- less than or equal to
.
The result is true if the value of the named Field
is less than or equal to the Value
specified.
See Datatype
for how different datatypes are handled.
Basic comparison -- greater than
.
The result is true if the value of the named Field
is greater than the Value
specified.
See Datatype
for how different datatypes are handled.
Basic comparison -- greater than or equal to
.
The result is true if the value of the named Field
is greater than or equal to the Value
specified.
See Datatype
for how different datatypes are handled.
Tests if the span value named by the Field
begins with the text specified in the Value
parameter.
Comparisons are case-sensitive and exact.
Values are always coerced to strings -- the Datatype
parameter is ignored.
Tests if the span value named by the Field
contains the text specified in the Value
parameter.
Comparisons are case-sensitive and exact.
Values are always coerced to strings -- the Datatype
parameter is ignored.
Tests if the span value named by the Field
does not contain the text specified in the Value
parameter.
Comparisons are case-sensitive and exact.
Values are always coerced to strings -- the Datatype
parameter is ignored.
For most cases, use does-not-contain
in a rule with a scope of "span".
WARNING: Rules can have Scope: trace
or Scope: span
; does-not-contain
used with Scope: trace
will be true if any single span in the entire trace matches the negative condition.
This is almost never desired behavior.
Tests if the specified span contains the field named by the Field
parameter, without considering its value.
Both the Value
and the Datatype
parameters are ignored.
Tests if the specified span does not contain the field named by the Field
parameter, without considering its value.
Both the Value
and the Datatype
parameters are ignored.
For most cases, use not-exists
in a rule with a scope of "span".
WARNING: Rules can have Scope: trace
or Scope: span
; not-exists
used with Scope: trace
will be true if any single span in the entire trace matches the negative condition.
This is almost never desired behavior.
Tests if the trace as a whole has a root span.
The Value
parameter can either be true
or false
.
NOTE: has-root-span
does not check if a given span is a root span,
it checks if the containing trace has a root span.
Tests if the span value specified by the Field
parameter matches the regular expression specified by the Value
parameter.
The regular expression grammar used is the syntax used by the Go programming language.
It is documented here.
For clarity, regular expressions in YAML should usually be quoted with single quotes ('
).
This is because this form is unambiguous and does not process escape sequences, and thus regular expression character classes like \d
for digits can be used directly.
For example, an expression to match arbitrary strings of digits would be '\d+'
.
Sometimes double-quoted ("
) strings are required in order to express patterns containing less common characters.
These use escape sequences beginning with a backslash (\
). This implies that backslashes intended for the regular expression will have to be doubled.
The same expression as above using double quotes looks like this: "\\d+"
.
Example:
RulesBasedSampler:
Rules:
- Name: Drop traces for any path element starting with /health or /status
Conditions:
- Field: http.target
Operator: matches
Value: '/(health/status)\w+'
Values are always coerced to strings -- the Datatype
parameter is ignored.
The Value
parameter can be any value of a supported type.
Its meaning and interpretation depends on the Operator
in use.
See Datatype
for how different datatypes are handled.
The Datatype
parameter controls the type of the values used when evaluating rules for the basic comparison operators.
When Datatype
is present, before evaluating the Operator
, both the span value and the Value
parameter are coerced (converted if necessary) to the specified format, and the comparison takes place as appropriate for that datatype.
There are 4 possibilities:
string
-- The comparison uses string operations. (For example, "2" is considered to be greater than "10" because '2' > '1'.)int
-- The comparison uses integers. (1.5 == 1 because1.5
gets converted to1
)float
-- The comparison uses floating point values.bool
-- The comparison tries to convert values to boolean. Note that because of the semantics of YAML, theValue
parameter will interpret not onlytrue/false
but also all ofyes/no
,y/n
, andon/off
as boolean values. Span values, for historical reasons, interprettrue/false
and1/0
as boolean, and all other values are considered to befalse
.
If the Datatype
parameter is not specified, then Refinery determines the type of the incoming span value. If the value is numeric or boolean, it attempts to convert the Value
parameter to the same type. If the span value is a string, the Value
parameter must also be a string or the comparison will fail.