XmlCollector
The XmlCollector collects and extracts metrics from XML and JSON documents.
Configuration and use
Class Name |
|
Package |
core |
Supported on Minion |
Yes (see limitations) |
Configuration Files |
$OPENNMS_HOME/etc/xml-datacollection-config.xml |
Configuration and use
Parameter | Description | Default |
---|---|---|
Required |
||
collection |
The name of the XML Collection to use. |
n/a |
Optional |
||
handler-class |
Class that performs the collection. |
org.opennms.protocols.xml.collector.DefaultXmlCollectionHandler |
The available handlers include:
-
org.opennms.protocols.xml.collector.DefaultXmlCollectionHandler
-
org.opennms.protocols.xml.collector.Sftp3gppXmlCollectionHandler
-
org.opennms.protocols.xml.vtdxml.DefaultVTDXmlCollectionHandler
-
org.opennms.protocols.xml.vtdxml.Sftp3gppVTDXmlCollectionHandler
-
org.opennms.protocols.json.collector.DefaultJsonCollectionHandler
-
org.opennms.protocols.http.collector.HttpCollectionHandler
XML collection configuration
Understanding resource types helps when editing collector-specific configuration files.
XML Collections are defined in etc/xml-datacollection-config.xml
and etc/xml-datacollection/
.
This snippet provides a collection definition named xml-opennms-nodes
:
<xml-collection name="xml-opennms-nodes">
<rrd step="300">
<rra>RRA:AVERAGE:0.5:1:2016</rra>
<rra>RRA:AVERAGE:0.5:12:1488</rra>
<rra>RRA:AVERAGE:0.5:288:366</rra>
<rra>RRA:MAX:0.5:288:366</rra>
<rra>RRA:MIN:0.5:288:366</rra>
</rrd>
<xml-source url="http://admin:admin@{ipaddr}:8980/opennms/rest/nodes">
<request method="GET">
<parameter name="use-system-proxy" value="true"/>
</request>
<import-groups>xml-datacollection/opennms-nodes.xml</import-groups>
</xml-source>
</xml-collection>
The request element can have the following optional child elements:
Parameter | Description | Default |
---|---|---|
timeout |
The connection and socket timeout in milliseconds. |
n/a |
retries |
How often to repeat the request in case of an error. |
0 |
disable-ssl-verification |
Do not attempt to verify the name on the SSL certificate against the |
false |
use-system-proxy |
Should the system-wide proxy settings be used? Configure the system proxy settings via system properties. |
false |
The referenced opennms-nodes.xml
file contains:
<xml-groups>
<xml-group name="nodes" resource-type="node" resource-xpath="/nodes">
<xml-object name="totalCount" type="GAUGE" xpath="@totalCount"/>
</xml-group>
</xml-groups>
HTTP headers
If the endpoint being collected requires additional headers, you can add them as part of the <request>
object.
<xml-source url="https://{nodelabel}/api/path/to/endpoint">
<request method="GET">
<header name="Authorization" value="Bearer static_token_here" />
<header name="X-Api-Key" value="api-key-here" />
</request>
<import-groups>xml-datacollection/file.xml</import-groups>
</xml-source>