The followings describe how patterns work. This information applies to program patterns and message patterns alike, even though message patterns are used to illustrate the procedure.
Patterns can consist of literals (keywords, or rather, keycharacters) and pattern parsers. Pattern parsers attempt to parse a sequence of characters according to certain rules.
![]() |
Note |
|---|---|
Wildcards and regular expressions cannot be used in patterns. The
|
When a new message arrives, syslog-ng attempts to classify it using the pattern database. The available patterns are organized alphabetically into a tree, and syslog-ng inspects the message character-by-character, starting from the beginning. This approach ensures that only a small subset of the rules must be evaluated at any given step, resulting in high processing speed. Note that the speed of classifying messages is practically independent from the total number of rules.
For example, if the message begins with the Apple string, only
patterns beginning with the character A are considered. In the
next step, syslog-ng selects the patterns that start with Ap, and
so on, until there is no more specific pattern left.
Note that literal matches take precedence over pattern parser matches: if at a step
there is a pattern that matches the next character with a literal, and another pattern
that would match it with a parser, the pattern with the literal match is selected. Using
the previous example, if at the third step there is the literal pattern
Apport and a pattern parser
Ap@STRING@, the Apport pattern is matched,
even if the pattern parser would result in a better match.
If there are two parsers at the same level (e.g., Ap@STRING@
and Ap@QSTRING@), it is random which pattern is applied
(technically, the one that is loaded first). However, if the selected parser cannot
parse at least oe character of the message, the other parser is used. But having two
different parsers at the same level is extremely rare, so the impact of this limitation
is much less than it appears.
© 2007-2010 BalaBit IT Security
Please send your comments or documentation bugs to: documentation@balabit.com