Vitrage Notifier plugins - SNMP

Overview

The Evaluator may determine that an alarm should be created, deleted or otherwise updated.

Other components are notified of such changes by the Vitrage Notifier service. Among others, Vitrage Notifier is responsible for sending snmp traps for raised and deleted deduced alarms.

This document describes the implementation of generating SNMP Traps on Vitrage alarms.

SNMP Plugin

The OIDs of the SNMP traps on Vitrage alarms should correspond to the definitions in the MIB file(s) used by the relevant companies. The traps should be sent on activation and deactivation of alarms.

In order to use the SNMP plugin:

  1. The default SNMP sender: vitrage.notifier.plugins.snmp.snmp_sender.py, in order to use it:

  • Add to vitrage.conf:

    • notifiers = snmp

    • [snmp]

      consumers = <path to consumers yaml file> alarm_oid_mapping = <path to alarm oid mapping yaml file> oid_tree = <path to tree format oid configuration yaml file>

  • consumers file should be in the following format:

      - host:
          name: <subscriber name>
          send_to: <subscriber ip>
          port: <subscriber port>
          community: <community string: for example public>
    
    There can be more then one host
    
  • alarm_oid_mapping file should be in the following format:

    For each alarm:

    <headline>:
    oid: '.<number>'
    alarm_name: <alarm name as appears in Vitrage deduced alarms>
    
  • oid_tree file should be in the following format:

    severity_mapping:
        <mapped severity>: <number>
    
    snmp_tree:
        root:
            oid: <num.num....>
            next:
                node:
                    oid: <num.num....>
                    next:
                        ...
                        next:
                            node:
                            oid: <num.num....>
                            next:
                                node:
                                    oid: <num.num....>
                                    with_values: 1
                                    next:
                                        leaf:
                                            oid: <num.num....>
                                        leaf2:
                                            oid: <num.num....>
                                        ...
                                node:
                                    oid: <num.num....>
                                    next:
                                        ...
                                        next:
                                            node
                                            oid: <num.num....>
                                            next:
                                                ALARM_OID:
                                                    oid: <no num>
                                                    next:
                                                        SEVERITY: - optional
                                                            oid: <no num>
    

“with_values” defines the parameters which’s values should be sent in the snmp trap. If it’s value is “1” then all it’s children’s values will be sent in the snmp trap.

SEVERITY is an optional parameter, if it exists then severity mapping should exist

  1. Optional: for defining other SNMP sender:

  • Create a package with SNMP sender

  • New SNMP sender should inherit from abstract class: vitrage.vitrage.notifier.plugins.snmp.base.py

  • Define the package in vitrage.conf under [snmp] section:

    • snmp_sender_class = <Snmp sender class location>