matcher
- string
- glob
- regexp
- simple patterns
Depending on the symbol at the start of the string, the matcher
will use one of the supported formats.
matcher | short format | long format |
---|---|---|
string | = | string |
glob | * | glob |
regexp | ~ | regexp |
simple patterns | simple_patterns |
Example:
* pattern
: It will use theglob
matcher to find thepattern
in the string.
#
SyntaxTip: Read ::=
as is defined as
.
When using the short syntax, you can enable the glob format by starting the string with a *
, while in the long syntax
you need to define it more explicitly. The following examples are identical. simple_patterns
can be used only with
the long syntax.
Examples:
- Short Syntax:
'* * '
- Long Syntax:
'glob:*'
#
String matcherThe string matcher reports whether the given value equals to the string.
Examples:
'= foo'
matches only if the string isfoo
.'!= bar'
matches any string that is notbar
.
String matcher means exact match of the string
. There are other string match related cases:
- string has prefix
something
- string has suffix
something
- string contains
something
This is achievable using the glob
matcher:
* PREFIX*
, means that it matches with any string that starts withPREFIX
, e.gPREFIXnetdata
* *SUFFIX
, means that it matches with any string that ends withSUFFIX
, e.gnetdataSUFFIX
* *SUBSTRING*
, means that it matches with any string that containsSUBSTRING
, e.gnetdataSUBSTRINGnetdata
#
Glob matcherThe glob matcher reports whether the given value matches the wildcard pattern. It uses the standard golang
library path
. You can read more about the library in the golang documentation,
where you can also practice with the library in order to learn the syntax and use it in your Netdata configuration.
The pattern syntax is:
Examples:
* ?
matches any string that is a single character.'?a'
matches any 2 character string that starts with any character and the second character isa
, likeba
but notbb
orbba
.'[^abc]'
matches any character that is NOT a,b,c.'[abc]'
matches only a, b, c.'*[a-d]'
matches any string (*
) that ends with a character that is betweena
andd
(i.ea,b,c,d
).
#
Regexp matcherThe regexp matcher reports whether the given value matches the RegExp pattern ( use regexp.Match ).
The RegExp syntax is described at https://golang.org/pkg/regexp/syntax/.
Learn more about regular expressions at RegexOne.
#
Simple patterns matcherThe simple patterns matcher reports whether the given value matches the simple patterns.
Simple patterns are a space separated list of words. Each word may use any number of wildcards *
. Simple patterns
allow negative matches by prefixing a word with !
.
Examples:
!*bad* *
matches anything, except all those that contain the word bad.*foobar* !foo* !*bar *
matches everything containing foobar, except strings that start with foo or end with bar.