The Round Robin Database Framework configuration consists of
several XML files. Once the XML configuration is changed, it must
be compiled into the database by executing $RRFW_HOME/bin/compilexml
.
Also, when Renderer notices the database changes, it flushes its cache.
The top-level XML element is always <configuration>
, with
sub-elements defining various sections, like datasources or views:
<configuration>
<!-- Optional inclusion of other XML files --> <include filename="myconfig.xml"/>
<datasources> <!-- Data sources tree definition --> ... </datasources> <views> <!-- View definitions --> ... </views> <token-sets> <!-- Token sets definitions -> ... </token-sets> <monitors> <!-- Monitor definitions -> ... </monitors> </configuration>
Multiple XML files are interpreted in additive matter, i.e.
<datasources>
section from one file is concatenated with
the corresponding sections of previous files.
Additional XML files may be added to the compilation list by means of
<include>
statement. They will be processed recursively
before the content of the XML file they are referenced from.
The argument filename
determines the
name of the file in standard XML files directory.
It is safe to include the same file several times,
RRFW compiler guarantees that files are only processed once.
Some kinds of sections, like <datasources>
, allow to
define the same elements two or more times. In this case,
the previous parameter values are overridden by the new values.
Each component of the configuration is defined by the set of parameters. They are specified in a common manner, differentiating in parameter names only:
<view name="default-rrd-html"> <param name="view-type" value="html" /> <param name="expires" value="300" /> <param name="html-template" value="default-rrd.html" /> </view>
The parameter value can be specified either by value
XML attribute,
or by the text contents of the <param>
element.
Some parameter values require other parameters to be defined, like in the
above example: a view of type html
cannot exist without a template.
After all XML files are compiled, the parameters are checked for validity by the compiler.
By default, all XML input is treated as UTF-8 (unicode). This is important because all the HTML output generated by RRFW is encoded UTF-8.
However, you may use Latin1 (ISO-8859-1) encoding in your XML files. In order to ensure correct displaying of non-ASCII characters, the encoding must be specified in your XML files:
<?xml version="1.0" encoding="ISO-8859-1"?>
You need this only in those files containing non-ASCII characters in Latin1 encoding.
In addition, version 1.54_3
or higher of XML::LibXML
is required, and
RRFW version 0.0.16 or above.
In the top level of the configuration tree, a number of macros may be defined.
Currently they are used in snmp-object
parameter only.
Macros are specified with <def>
elements, being the direct
children of <definitions>
element:
<configuration> <definitions> <!-- IF-MIB:ifTable --> <def name="ifDescr" value="1.3.6.1.2.1.2.2.1.2" /> <def name="ifPhysAddress" value="1.3.6.1.2.1.2.2.1.6" /> <def name="ifInOctets" value="1.3.6.1.2.1.2.2.1.10" /> <def name="ifInUcastPkts" value="1.3.6.1.2.1.2.2.1.11" /> <def name="ifInErrors" value="1.3.6.1.2.1.2.2.1.14" /> <def name="ifOutOctets" value="1.3.6.1.2.1.2.2.1.16" /> <def name="ifOutUcastPkts" value="1.3.6.1.2.1.2.2.1.17" /> <def name="ifOutErrors" value="1.3.6.1.2.1.2.2.1.20" />
<!-- Default Interface index lookup --> <def name="IFIDX" value="M($ifDescr, %interface-name%)" /> </definitions> ...
These definitions are global across all XML configuration files, and are referenced with dollar sign and the definition name, e.g.:
<leaf name="ifInErrors"> <param name="snmp-object" value="$ifInErrors.$IFIDX" /> ...
Datasources are organized into a tree hierarchy. All parameters are inherited by the subtrees and leafs from their parents, and can be overridden on lower levels.
The datasources tree consists of two key types of components: subtree and leaf. A subtree can have child subtrees or leaves. A leaf can never have children. A subtree represents logical aggregation, while the leaf always represends the actual datasource.
In XML configuration, a child subtree or leaf belongs to the parent element, like the following:
<datasources> <!-- This is the first child of the tree root --> <subtree name="Netflow"> <param name="ds-type" value="rrd-file" /> <param name="comment" value="Netfow data collected by FlowScan with CarrierIn.pm" /> <!-- All Flowscan-generated files reside here --> <param name="data-dir" value="/var/local/flowscan/graphs" /> <subtree name="Exporters"> <param name="comment" value="Netflow exporting devices" /> ... <!-- all exporters defined here --> </subtree> ... <subtree name="Total"> <param name="data-file" value="total.rrd" /> <leaf name="bps"> <param name="comment" value="Bits per second" /> <param name="leaf-type" value="rrd-def" /> <param name="rrd-ds" value="bits" /> <param name="rrd-cf" value="AVERAGE" /> </leaf> <leaf name="pps"> <param name="comment" value="Packets per second" /> <param name="leaf-type" value="rrd-def" /> <param name="rrd-ds" value="pkts" /> <param name="rrd-cf" value="AVERAGE" /> </leaf> <leaf name="packlen"> <param name="comment" value="Average packet length in bytes" /> <param name="leaf-type" value="rrd-cdef" /> <param name="rpn-expr" value="{bps},8,/,{pps},/" /> </leaf> </subtree> </subtree> </datasources>
Each subtree or a leaf is identified by a path, the symbolic notation similar to filesystem paths. In any path notation, subtree names always end with slash (/), and this trailing slash is the part of the name. In this case, any subtree is identified by a path ending with slash, while leaf paths always end with a word symbol. The top-level subtree is identified by a single slash.
The other components of the datasouce definition are templates, aliases, and filepatterns.
A template is used when it's needed to define multiple different pieces of the configuration in the same way. For instance, the definition for input/output octets and bits can be specified once in a template, and then applied where appropriate.
The piece of XML configuration inside the <template>
element is memorized under the template name, and reproduced
in every occurrence of <apply-template>
with the corresponding
template name. The template definition must be the direct child
element of <configuration>
XML element:
<datasources> <!-- Default views must be defined --> <param name="default-subtree-view" value="default-dir-html" /> <param name="default-leaf-view" value="default-rrd-html" />
<!-- Many of our RRDs have the field "bits" - let's define it here --> <template name="bps"> <leaf name="bps"> <param name="comment" value="Bits per second" /> <param name="leaf-type" value="rrd-def" /> <param name="rrd-ds" value="bits" /> <param name="rrd-cf" value="AVERAGE" /> </leaf> </template> ... <subtree name="Total"> <param name="data-file" value="total.rrd" /> <apply-template name="bps" /> <leaf name="pps"> <param name="comment" value="Packets per second" /> <param name="leaf-type" value="rrd-def" /> <param name="rrd-ds" value="pkts" /> <param name="rrd-cf" value="AVERAGE" /> </leaf> <leaf name="packlen"> <param name="comment" value="Average packet length in bytes" /> <param name="leaf-type" value="rrd-cdef" /> <param name="rpn-expr" value="bps,8,/,pps,/" /> </leaf> </subtree>
Alias is the alternative symbolic name for a subtree or a leaf. It can be even a name from a different subtree hierarchy. If that alternative hierarchy does not exist, the corresponding subtrees are created:
<subtree name="62.3.44.55"> <alias>/Netflow/ExportersByName/rtrTelehouse1/</alias> ...
Some subtree hierarchies can be built based on file name pattern. Suppose you have a bunch of RRD files named conforming to a known rule. In this case, filepatterns allow to build the subtrees based on those names.
Parameter data-dir
must be defined in the parent node. It determines
the directory where the files are searched.
A filepattern is defined by three mandatory attributes:
subtree
or leaf
. It defines what kind of elements
will be built in the configuration tree.
$1
etc.
(.*)
etc.
At the time of compilation, the files are scanned in the given directory,
and for those matched, the new subtrees or leaves are created, with one
parameter implicitly defined: data-file
is set to the file name
being matched.
The string given in filere
attribute, is a normal Perl regular expression,
except one thing: $PARENT
is replaced by the parent subtree name.
This allows to build nested filepattern constructs:
<subtree name="Exporters"> <param name="comment" value="Netflow exporting devices" /> <param name="data-dir" value="/var/local/flowscan/graphs" />
<!-- All netflow exporters look the same from here --> <filepattern type="subtree" name="$1" filere="exporter_(.*)_total\.rrd"> <param name="comment" value="" />
<!-- And here we describe the difference --> <detailed match="62.5.55.233"> <!-- Let's give it a nicer name --> <alias>/Netflow/ExportersByName/rtrTelehouse1/</alias> <!-- And give all the paramal details if needed --> <param name="location" value="Telehouse Street 1, New Yourk" /> <param name="contact" value="John Smith" /> <param name="phone" value="+1-800-444555" /> <subtree name="if11"> <param name="comment" value="France Telecom 1" /> <param name="phone" value="+1-800-666555" /> <!-- We can give it a name from different subtree --> <alias>/Netflow/Peering/FranceTelecom-1/</alias> </subtree> </detailed>
<!-- Again, on each router, the interfaces look the same --> <filepattern type="subtree" name="'if'.$1" filere="exporter_$PARENT_(\d.*)\.rrd"> <param name="comment" value="Netflow exporting interface" />
<!-- For each of the interfaces, the bps leaf is taken from the template above --> <apply-template name="bps" /> </filepattern> </filepattern>
</subtree>
In this example, the files are searched in the directory /var/local/flowscan/graphs, and those matching the patterns exporter_[router-ip]_total.rrd and exporter_[router-ip]_[if-index].rrd build the corresponding hierarchy.
The construct <detailed match="[name]">
allows to
specify additional parameters for the subtree or leaf whose name
coincides the given string. Should no elements match the given name, a warning
message is issued by the compiler.
Compile-time variables are those defined somewhere in datasource hierarchy, and valid within a given subtree and its children. It is possible to define pieces of XML configuration which are or are not compiled, depending on the value of corresponding variable.
Variables are set by setvar
XML element, with mandatory attributes
name
and value
.
Variable values are used in iftrue
and iffalse
XML elements.
Mandatory parameter var
specifies the variable name. The child XML elements
are compiled if the variable value is true or false, correspondingly.
A true value is true
or a nonzero number. Undefined variable is identified
as false.
Example:
<template name="cisco-cbqos-classmap-meters"> ... <iftrue var="CiscoIOS_cbQoS::CMNoBufDrop"> <leaf name="Dropped_No_Buffer"> ... </leaf> </iftrue> </template>
<subtree name="QoS_Stats"> <setvar name="CiscoIOS_cbQoS::CMNoBufDrop" value="true"/> .... </subtree>
For any given leaf, some parameters may reference the other parameter values, by embracing the parameter name with percent signs:
<param name="data-file" value="%snmp-host%_hostaverages.rrd" />
The parameter substitution is performed at runtime. The substitution formula may be defined at a higher subtree level, and the substitution itself will occur at leaf level.
Currently parameter substitution is supported for the following parameters: data-file data-dir rrd-ds rpn-expr rrd-create-max rrd-create-min monitor-vars comment graph-title graph-legend descriptive-nickname collector-timeoffset-hashstring collector-scale lower-limit normal-level upper-limit transform-value
ds-type
rrd-file
or RRDfile
RRDfile
is the old syntax, and is supported for compatibility
only.
Implies mandatory parameters: data-dir
, data-file
, leaf-type
.
collector
collector-type
, storage-type
,
collector-period
, collector-timeoffset
.
rrd-multigraph
comment
help-text
[%em('some text')%]
would be displayed in italics, and
[%strong('some text')%]
would be bold.
monitor
monitor-period
and monitor-timeoffset
.
monitor-period
, monitor-timeoffset
monitor
defined.
They define the monitor schedule for each individual datasource.
The time for execution is determined by formula:
time + period - (time mod period) + timeoffset
monitor-vars
#varname
. These
variables are looked up in the leaf's monitor-vars
parameter.
The syntax of this parameter is semicolon-delimited name=value
pairs:
<param name="monitor-vars" value="min=300000;max=1000000"/>
monitor-action-target
precedence
0
. When rendering, the subtree listing is
sorted according to precedence and alphabetic order of names.
The higher the precedence, the closer to the top of the list
the child node is displayed.
legend
Category1:Value1; Category2:Value2...
.
Spaces around the delimiters are ignored.
Example:
<subtree name="rtrZurich1"> <param name="legend"> Location:Zurich; Contact: John Smith; Telephone: 01 9911299 </param>
graph-title
graph-legend
vertical-label
graph-lower-limit
, graph-upper-limit
graph-rigid-boundaries
rrd-scaling-base
graph-logarithmic
default-subtree-view
, default-leaf-view
rrgraph-views
tokenset-member
<token-sets>
part of configuration.
descriptive-nickname
hidden
yes
, no
.
When set to yes
, the leaf or subtree is not
displayed in the subtree listing,
unless SHOWHIDDEN
option is true. When SHOWHIDDEN
is enabled,
the node name and comment are shown in italics.
has-overview-subleaves
, overview-subleave-name
,
overview-shortcut-text
, overview-shortcut-title
,
overview-page-title
, overview-direct-link
, overview-direct-link-view
has-overview-subleaves
is set to yes
on a subtree level,
default HTML templates expect the other four parameters to be set.
overview-subleave-name
defines the current subtree's grandchild
leaves name which would compose the overview page.
When overview-direct-link
is set to yes
, the URL under the
graph will point to the direct child subtree, and
overview-direct-link-view
will define the view for that subtree.
Usually this view would be expanded-dir-html
.
ignore-lower-limit
, ignore-upper-limit
, ignore-limits
yes
, they make the renderer ignore
graph-lower-limit
, graph-upper-limit
, or both, accordingly.
In addition, ignore-limits
disables the graph-rigid-boundaries
parameter.
graph-ignore-decorations
yes
, the view decorations
are ignored.
graph-disable-gprint
yes
, the view parameter gprint-values
and other
GPRINT-related parameters are ignored.
data-dir
data-file
leaf-type
rrd-def
rrd-ds
and rrd-cf
, giving the DS name and consolidation
function, correspondingly.
rrd-cdef
ds-type=rrd-file
only.
Corresponds to CDEF specification in RRDgraph query. Implies one
mandatory parameter: rpn-expr
, which gives the RPN expression.
Other leaves' value references are specified in curly braces. These leaves
can be specified as relative or absolute paths in the configuration tree.
See RPN expressions in RRFW manual for more details.
rrd-hwpredict
enabled
, then this RRD datasource
is expected to have HWPREDICT and all the suite of
Holt-Winters consolidation functions.
In case of ds-type=collector
, rrd-hwpredict=enabled
indicates
that the RRD file must be created with use of Holt-Winters RRAs.
rrd-create-dstype
ds-type=collector
and storage-type=rrd
.
Specifies the datasource type for RRD creation. Valid values are:
GAUGE
, COUNTER
, DERIVE
, ABSOLUTE
.
rrd-create-rra
ds-type=collector
and storage-type=rrd
.
Space-separated list of RRA definitions for RRD creation, as they
are passed to RRD Create command.
Example:
<!-- Round-robin arrays to be created, separated by space. In this example, we keep 5-minute details for 2 weeks, 30-minute average and maximum details for 6 weeks, and 1-day aggregated stats for 2 years --> <param name="rrd-create-rra"> RRA:AVERAGE:0.5:1:4032 RRA:AVERAGE:0.5:6:2016 RRA:MAX:0.5:6:2016 RRA:AVERAGE:0.5:288:732 RRA:MAX:0.5:288:732 </param>
rrd-create-heartbeat
ds-type=collector
and storage-type=rrd
.
Heartbeat parameter as defined in RRD Create manual page.
rrd-create-min
, rrd-create-max
rrd-create-hw-rralen
ds-type=collector
and storage-type=rrd
and rrd-hwpredict=enabled
. Specifies the RRA length for
Holt-Winters archives. Recommended same length as main 5-minutes RRA.
rrd-create-hw-season
, rrd-create-hw-alpha
,
rrd-create-hw-beta
, rrd-create-hw-gamma
,
rrd-create-hw-winlen
, rrd-create-hw-failth
season=288 alpha=0.1, beta=0.0035, gamma=0.1, window_length=9, failure_threshold=6
collector-type
collector
. Currently supported
value is: snmp
. Other valid values may be added with plugins.
storage-type
collector
. The only supported value
is rrd
.
collector-period
, collector-timeoffset
collector
.
They define the collector schedule for each individual datasource.
The time for execution is determined by formula:
time + period - (time mod period) + timeoffset
collector-dispersed-timeoffset
yes
, compilexml
spreads the collector offsets
among values determined from collector-timeoffset-min
,
collector-timeoffset-max
, collector-timeoffset-step
,
and collector-timeoffset-hashstring
.
collector-timeoffset-min
,
collector-timeoffset-max
, collector-timeoffset-step
collector-dispersed-timeoffset
is set to yes
.
They define the limits and the step for collector timeoffset dispersion.
collector-timeoffset-hashstring
collector-dispersed-timeoffset
is set to yes
.
Defines the string that is used as a hash for timeoffset dispersion.
transform-value
DOLLAR
is replaced with the dollar sign ($),
and MOD
is replaced with the percent sign (%).
The initial value is supplied in $_
, which should be referenced as
DOLLAR_
in your Perl code.
The code should return a numeric value or U
for an undefined
value. The returned value is then passed to the storage.
The parameter substititions are performed on the value of the
parameter, therefore it should not contain the percent(%)
and dollar ($) signs.
value-map
value:number
pairs.
collector-scale
snmp-host
collector-type=snmp
. Specifies the hostname or IP address
of the SNMP agent.
snmp-port
collector-type=snmp
. Specifies the UDP port of the
SNMP agent.
domain-name
snmp-host
does not contain
dot symbol (.), this domain name is appended to snmp-host
.
snmp-community
collector-type=snmp
. Specifies the SNMP community for
the given device.
snmp-version
collector-type=snmp
. Specifies the SNMP version for the
given device. Valid values are: 1
, 2c
.
snmp-timeout
collector-type=snmp
. Specifies the SNMP session timeout
in seconds.
snmp-retries
collector-type=snmp
. Specifies the SNMP session retry count.
snmp-oids-per-pdu
collector-type=snmp
. Specifies the number of SNMP OIDs per
one UDP packet.
snmp-object
collector-type=snmp
. Specifies the SNMP OID to be polled
from the agent. The object must return a single numeric value.
In order to reference the dynamic instances, i.e. interface counters, two mapping types are supported: reverse mapping and variable value substitution.
Reverse mapping has syntax as follows:
M(baseoid, string)
The result of reverse mapping is the tail of the OID which has the head
baseoid
and whose value equals the string.
Variable value substitution is defined by syntax:
V(oid)
The returned value must be a numeric value which is substituted in place of this expression.
snmp-object-type
COUNTER64
, OTHER
. When set to COUNTER64
,
the SNMP variable value is treated as 64-bit integer. Not using this
parameter may lead to loss of precision.
snmp-check-sysuptime
yes
. When set to no
, the collector does not
query SNMPv2-MIB::sysUpTime
(1.3.6.1.2.1.1.3.0
). By default,
the uptime counter is used to detect if the agent was rebooted between
the collector cycles. In this case the dynamic maps for the given host
are automatically rebuilt. This parameter is needed for compatibility
with some non-standard agents which don't implement this OID.
system-id
%snmp-host%
. Unique identifier of the host.
This parameter is used in various template definitions for
data-file
and descriptive-nickname
.
The leaves with ds-type=rrd-multigraph
are dedicated for
displaying of several datasource values in one graph.
Such leaves cannot be referenced for a numerical value, hence
cannot be monitored.
Example:
<subtree name="SampleMulti"> <leaf name="sample1"> <param name="ds-type" value="rrd-multigraph" /> <param name="ds-names" value="in,out" /> <param name="foobarpath" value="/SNMP/Routers/213.230.38.4/FastEthernet0_0" />
<!-- parameter name tail is formed by the DS name -->
<param name="ds-expr-in" value="{%foobarpath%/locIfInBitsSec}" /> <param name="graph-legend-in" value="Bits per second in" /> <param name="line-style-in" value="AREA" /> <param name="line-color-in" value="#00FF00" /> <param name="line-order-in" value="1" />
<param name="ds-expr-out" value="{%foobarpath%/locIfOutBitsSec}" /> <param name="graph-legend-out" value="Bits per second out" /> <param name="line-style-out" value="LINE2" /> <param name="line-color-out" value="#0000FF" /> <param name="line-order-out" value="2" />
</leaf> </subtree>
Parameters:
ds-names
X
stands for the DS name.
ds-expr-X
%parameter_name%
.
graph-legend-X
line-style-X
LINE1
, LINE2
etc.
Two hashes in the beginning and a name refer to the line style from
the styling profile, e.g. ##BpsIn
.
line-color-X
#0000FF
.
Two hashes in the beginning and a name refer to the color from
the styling profile, e.g. ##BpsIn
.
line-order-X
ignore-views-X
disable-gprint-X
yes
, this datasource is not included in GPRINT output.
In our context, view means any kind of object representation. The same subtree or view can be displayed in different ways and in different formats: HTML, graph image, plain text, etc.
Renderer module handles these view definitions. For any subtree or leaf, it renders the specified view, and keeps the cache of rendered files.
Each subtree or leaf must have a default view. This is controlled by
two parameters that may be defined in the root subtree:
default-subtree-view
and default-leaf-view
.
The set of views is flat, though they can inherit the parameters one from another. Each view is referenced by its name, and is defined by the set of parameters. Same way as with datasources, certain parameter values imply the neccessaty to define certain other parameters:
<views> <view name="default-rrgraph"> <param name="view-type" value="rrgraph" /> <param name="expires" value="300" /> <param name="width" value="500" /> <param name="height" value="250" /> <param name="width-hint" value="580" /> <param name="line-style" value="##SingleGraph" /> <param name="line-color" value="##SingleGraph" />
<!-- Daily graph, inherits parameters from the above --> <view name="last24h"> <param name="start" value="-24h" /> </view>
<!-- Weekly graph --> <view name="lastweek"> <param name="start" value="-7d" /> </view> </view> </views>
Currently the view is defined by the configuration only. Probably, in the future additional parameters will be supplied dynamically.
For every view, the mandatory parameters are:
view-type
expires
The following values of view-type
are recognized:
html
html-template
must contain a file
name of the HTML template. Those templates are copied from templates
subdirectory of the installation package. We use Template-Toolkit
<http://www.template-toolkit.org> for HTML processing.
The template file name is defined with the parameter html-template
.
The following variables and functions are defined when the template is processed:
token
view
path(token)
pathToken(path)
nodeExists(path)
children(path)
isLeaf(token)
sortTokens(array)
precedence
parameter.
nodeName(token)
parent(token)
nodeParam(token, param_name)
param(entity_name, param_name)
url(token, [view])
pathUrl(token, [view])
splitUrls(token, [view])
rrprint(token, view)
rrprint
. Returned is the text
output produced by this view.
scale(text)
rrprint
for better formatting.
tsetMembers(tset)
tsetList
stylesheet
$RRFW::Renderer::stylesheet
.
version
rrgraph
The following parameters are mandatory for this kind of view:
width
, height
, start
end
can also be given, it defaults to now
.
line-style
LINE1
, LINE2
etc.
Two hashes in the beginning and a name refer to the line style from
the styling profile, e.g. ##SingleGraph
.
line-color
#0000FF
.
Two hashes in the beginning and a name refer to the color from
the styling profile, e.g. ##SingleGraph
.
rrd-hwpredict
disabled
, HWPREDICT display is disabled for this view.
Note that if the datasource has rrd-hwpredict
parameter set to enabled
,
this emplies that the view would contain Holt-Winters boundaries and failures
graph.
hw-bndr-style
LINE1
. Specifies the line style for
Holt-Winters boundaries.
hw-bndr-color
#FF0000
. Specifies the color for
Holt-Winters boundaries.
hw-fail-color
#FFFFA0
. Specifies the color for
Holt-Winters failure ticks.
hrules
, hrule-value-name
, hrule-color-name
,
hrule-legend-name
hrules
contains a comma-separated list of
horizontal rule names. For each name, mandatory parameter
hrule-value-name
defines a name of the leaf parameter that will be
used as the horizontal rule value. The rule is not drawn if such parameter
is not defined for the leaf. Mandatory parameter hrule-color-name
defines the color for the rule, of the form #DDDDDD
, where D
corresponds
to a hexademical digit. Two hashes in the beginning and a name refer to
the color from the styling profile, e.g. ##HruleMin
.
Optional parameter hrule-legend-name
defines the legend text to be displayed on the graph. The following horizontal
rules are defined in defaults.xml for all rrgraph views:
<param name="hrules" value="min,norm,max"/> <param name="hrule-color-min" value="##HruleMin"/> <param name="hrule-value-min" value="lower-limit"/> <param name="hrule-color-norm" value="##HruleNormal"/> <param name="hrule-value-norm" value="normal-level"/> <param name="hrule-color-max" value="##HruleMax"/> <param name="hrule-value-max" value="upper-limit"/>
decorations
dec-order-<name>
determines the order of drawing. Negative order numbers correspond to
the lines or areas behind the data line. dec-expr-<name>
gives the RPN expression that defines the line or area.
dec-style-<name>
and dec-color-<name>
define
the style (AREA or LINE1..3) and the color of the drawing.
Node parameter graph-ignore-decorations
disables the decorations.
gprint-values
, gprint-header
, gprint-format-*
gprint-values
is a comma-separated list of format names,
and for each format name, there should be a corresponding gprint-format-*
parameter. gprint-header
defines a string that will be printed on top of
all orther lines. Example:
<param name="gprint-values" value="current,average,max,min"/> <param name="gprint-header" value="Current Average Maximum Minimum"/> <param name="gprint-format-current" value="LAST:%8.2lf%s"/> <param name="gprint-format-average" value="AVERAGE:%8.2lf%s"/> <param name="gprint-format-max" value="MAX:%8.2lf%s"/> <param name="gprint-format-min" value="MIN:%8.2lf%s"/>
description
rrd-params
rrprint
start
and print-cf
.
The first one defines the starting time. end
may be also optionally
specified.
print-cf
specifies oe or more consolidation functions, separated by comma.
The result of the rendering is the text line with the output values
separated by colon (:).
Styling profiles allow symbolic names to be used for line type and color.
Two hashes in the beginning and a name refer to the line style from
the styling profile, e.g. ##BpsIn
, ##green
, ##one
, ##two
.
<leaf name="InOutBytes"> <param name="comment" value="Input and Output bits per second graphs"/> <param name="ds-type" value="rrd-multigraph"/> <param name="ds-names" value="in,out"/> <!-- IN --> <param name="ds-expr-in" value="{ifInOctets}"/> <param name="graph-legend-in" value="Bytes per second in"/> <param name="line-style-in" value="##BpsIn"/> <param name="line-color-in" value="##BpsIn"/> <param name="line-order-in" value="1"/> <!-- OUT --> <param name="ds-expr-out" value="{ifOutOctets}"/> <param name="graph-legend-out" value="Bytes per second out"/> <param name="line-style-out" value="##BpsOut"/> <param name="line-color-out" value="##BpsOut"/> <param name="line-order-out" value="2"/> </leaf>
When processed the example above effectivly becomes:
<leaf name="InOutBytes"> <param name="comment" value="Input and Output bits per second graphs"/> <param name="ds-type" value="rrd-multigraph"/> <param name="ds-names" value="in,out"/> <!-- IN --> <param name="ds-expr-in" value="{ifInOctets}"/> <param name="graph-legend-in" value="Bytes per second in"/> <param name="line-style-in" value="AREA"/> <param name="line-color-in" value="#00FF00"/> <param name="line-order-in" value="1"/> <!-- OUT --> <param name="ds-expr-out" value="{ifOutOctets}"/> <param name="graph-legend-out" value="Bytes per second out"/> <param name="line-style-out" value="LINE2"/> <param name="line-color-out" value="#0000FF"/> <param name="line-order-out" value="2"/> </leaf>
Schema definitions can be modified in two ways (see the RRFW Styling Profile Guide manual for available styles and override details)
Token is a symbolic identifier for each subtree or a leaf. See Round Robin Framework Architecture manual for more details.
A tokenset is a named list of tokens. Its contents can be rendered, and its members can be added or removed at any time.
Each tokenset can have a number of parameters defined. It also
inherits the parameter defined in the top <token-sets>
XML element:
<token-sets>
<param name="default-tset-view" value="default-tset-html" /> <param name="default-tsetlist-view" value="tset-list-html" />
<token-set name="jumps"> <param name="comment" value="Traffic rate jumps" /> </token-set>
<token-set name="hw-failures"> <param name="comment" value="Holt-Winters prediction failures" /> </token-set>
</token-sets>
Parameter default-tsetlist-view
is mandatory for tokenset list.
It defines the default view when displaying the list of tokensets.
The following parameters are mandatory for tokensets:
default-tset-view
comment
Monitor is a named set of parameters that defines the behaviour
of monitor module. Each leaf can be given a number of monitors
via monitor
parameter.
Upon monitor module run, an action is launched if the alarm conditions of a given monitor are satisfied.
<monitors> <!-- First define the actions -->
<!-- This action will put the graphs of alarmed datasources in a single alarm report page --> <action name="graph-hw-failures"> <param name="action-type" value="tset" /> <param name="set-name" value="hw-failures" /> </action>
<action name="graph-jumps"> <param name="action-type" value="tset" /> <param name="set-name" value="jumps" /> </action>
<monitor name="hw-failures"> <param name="monitor-type" value="failures" /> <param name="action" value="graph-hw-failures" /> <param name="expires" value="3600" /> </monitor>
<!-- alarm if 5 minutes away it was 10 times lower --> <monitor name="high-jumps"> <param name="monitor-type" value="expression" /> <param name="rpn-expr" value="{(-300)},10,*,GT,{},{(-300)},10,/,LT,OR" /> <param name="action" value="graph-jumps" /> <param name="expires" value="3600" /> <param name="comment" value="Value jumped more than 10-fold in 5 minutes" /> </monitor>
<monitor name="hundred-megs"> <param name="monitor-type" value="expression" /> <param name="rpn-expr" value="100,1024,1024,*,*,GT" /> <param name="action" value="graph-jumps" /> <param name="expires" value="3600" /> <param name="comment" value="Traffic is higher than 10 mbps" /> </monitor> </monitors>
Should the alarm condition occur, a series of events is happening in sequentional order:
set
repeat
clear
forget
monitor-type
failures
expression
rpn-expr
parameter. The current leaf value is prepended to the given RPN.
rpn-expr
expression
. Defines the RPN expression to
evaluate. The current leaf value is prepended to the given RPN.
The expresion may reference leaf-dependent variables: the
constructs of the form #varname
are replaced with the variable
value specified in the leaf's monitor-vars
parameter.
action
expires
comment
action-type
tset
forget
.
This action type implies the parameter tset-name
.
exec
command
and optional launch-when
.
tset-name
tset
. Defines the tokenset name
where the leaf is added when the monitor condition is met.
command
exec
. Defines the external program to launch.
The following strings are substituted in the parameter value:
The following environment variables are passed to the child process:
$RRFW_HOME
prefix
where RRFW was installed.
$RRFW_BIN
$RRFW_UPTIME
$RRFW_TREE
, $RRFW_TOKEN
, $RRFW_NODEPATH
$RRFW_NCOMMENT
, $RRFW_NPCOMMENT
comment
parameter of the node and its parent.
Empty if the parameter is not defined for the given leaf.
$RRFW_EVENT
$RRFW_MONITOR
$RRFW_MCOMMENT
comment
parameter value.
$RRFW_TSTAMP
RRFW_VALUE
launch-when
exec
. The comma-separated list of event
types when the given action should be launched. If not defined,
the event type set
is used by default.
setenv-params
exec
. The comma-separated list of leaf parameters
which would be passed as environment variables to the child process.
The environment variables are of the form $RRFW_P_paramname
. Hyphens ('-')
are replaced with underscores ('_') in the parameter names.
setenv-dataexpr
exec
. Comma-separated list of ENV=paramname
pairs. ENV
defines the environment variable name: it is prefixed with
RRFW_
. paramname
defines the action parameter name. This parameter
is interpreted as RPN expression applied to the current leaf being monitored.
The result of this RPN expression is passed to the action script
in the environment variable.
Example:
<action name="report-temperature"> <param name="action-type" value="exec" />
<!-- This is our proprietary reporting script --> <param name="command"> /usr/local/bin/report_temperature </param> <param name="launch-when" value="set" />
<!-- We want to tell the action script the actual values of the "temperature" and "humidity" leaves in the current datasource tree --> <param name="setenv-dataexpr" value="TEMP=expr-temp, HMD=expr-hmd" /> <param name="expr-temp" value="{temperature(LAST)}" /> <param name="expr-hmd" value="{humidity(LAST)}" />
<!-- We also want to tell the action script the parameter "monitor-vars" which was configured for the current leaf. --> <param name="setenv-params" value="monitor-vars" /> </action>
Copyright (c) 2002-2003 Stanislav Sinyagin <ssinyagin@yahoo.com>