trying to associate bgp neighbor with interface

Post general support questions here that do not specifically fall into the Linux or Windows categories.

Moderators: Developers, Moderators

Post Reply
nnimrod
Posts: 4
Joined: Sun Mar 28, 2021 9:33 am

trying to associate bgp neighbor with interface

Post by nnimrod »

I've been beating my head on this one for a while now and can't seem to figure out the right incantations of rewrite_index and oid_rewrite_* to make this work.

What I'm trying to accomplish is to get the bgp remote ASN that's stored in .1.3.6.1.2.1.15.3.1.9 as an input field in an SNMP data query and have it associated with an interface ifIndex. The problem is that this OID is indexed using the bgp neighbor address. The neighbor address is available as a value at .1.3.6.1.2.1.15.3.1.7 and the local address (which is on the interface I want to ultimately use) is available .1.3.6.1.2.1.15.3.1.5 indexed by the neighbor address.

I've tried using the information in the arp table at .1.3.6.1.2.1.4.22.1.1 to get the neighbor address associated with the ifIndex, but because every address (local and remote) appear in the arp table with the ifIndex, this only works when the neighbor address appears second in the arp table.

Does anyone have any clues on how I can accomplish this?
nnimrod
Posts: 4
Joined: Sun Mar 28, 2021 9:33 am

Re: trying to associate bgp neighbor with interface

Post by nnimrod »

so this gets part of the job done:

Code: Select all

                <ifnei>
                        <name>neighbor</name>
                        <method>walk</method>
                        <source>OID/REGEXP:.*\.([0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3})$</source>
                        <direction>input</direction>
                        <oid>.1.3.6.1.2.1.4.22.1.1</oid>
                </ifnei>
                <ifbgpnei>
                        <name>bgp neighbor</name>
                        <method>get</method>
                        <source>value</source>
                        <direction>input</direction>
                        <oid>.1.3.6.1.2.1.15.3.1.9</oid>
                        <rewrite_index>|query_ifnei|</rewrite_index>
                </ifbgpnei>
But the problem is that walking .1.3.6.1.2.1.4.22.1.1 gives multiple values for each interface. The index is 'ifIndex.IPaddress' for every IP address that is in the arp table on that interface (usually only 2, local and remote since these are routers with point-to-point interfaces). The value for walking this OID is the ifIndex. So the result is only the last entry is kept in the table indexed as ifIndex. Unfortunately, I can't depend on the address I need being the last one in the list for each interface.

So I'm looking for a way to find the ifIndex of the values associated with each bgp neighbor listed at OID .1.3.6.1.2.1.15.3.1.7 (or the index, it's the same thing in this case), and index them by interface ifIndex.

This is a new installation of cacti version 1.2.16 if that makes any difference. I need this field so I can automate adding graphs. I'm open to other ways of getting this information associated with interfaces, even an external inventory would work.
nnimrod
Posts: 4
Joined: Sun Mar 28, 2021 9:33 am

Re: trying to associate bgp neighbor with interface

Post by nnimrod »

So far, nothing I've tried has worked out to get the bgp neighbor IP aligned with the interface ifIndex.
It's pretty clear that I have no idea how to use oid_rewrite_pattern and oid_rewrite_replacement.

I'm starting to think the only way to get this done is with a custom data query script. But I'm a little worried about going that path for all of my SNMP data collections since my goal is to be polling a lot of large routers and that scale could be a concern on the scripted side vs using a spine collector.

I'm hoping someone has an idea for how to combine this bgp neighbor information as an input field with SNMP collected interface stats so I can automate managing graphs based on this criteria.
nnimrod
Posts: 4
Joined: Sun Mar 28, 2021 9:33 am

Re: trying to associate bgp neighbor with interface

Post by nnimrod »

It's been interesting having this conversation with myself :D
But I'm hoping these updates will either give someone an idea that I haven't thought of or may help someone else in the future...

I've been able to do some manual manipulations to get what I want.

I've added this field to the interfaces.xml:

Code: Select all

                <ifbgpas>
                        <name>bgp neighbor</name>
                        <method>walk</method>
                        <source>value</source>
                        <direction>input</direction>
                        <oid>.1.3.6.1.2.1.15.3.1.9</oid>
                </ifbgpas>
and created a new data query with the following xml:

Code: Select all

<bgp>
        <name>Get SNMP BGP</name>
        <description>Queries a host for a list of monitorable BGP</description>
        <oid_index>.1.3.6.1.2.1.15.3.1.5</oid_index>
        <oid_index_parse>OID/REGEXP:.*\.([0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3})$</oid_index_parse>
        <index_order_type>numeric</index_order_type>
        <index_title_format>|chosen_order_field|</index_title_format>

        <fields>
                <ifbgpnei>
                        <name>Index</name>
                        <method>walk</method>
                        <source>value</source>
                        <direction>input</direction>
                        <oid>.1.3.6.1.2.1.15.3.1.5</oid>
                </ifbgpnei>
                <ifbgpas>
                        <name>bgp neighbor</name>
                        <method>walk</method>
                        <source>value</source>
                        <direction>input</direction>
                        <oid>.1.3.6.1.2.1.15.3.1.9</oid>
                </ifbgpas>
        </fields>
</bgp>
Then I can manually manipulate the database as follows (formatted to be more readable):

Code: Select all

delete from host_snmp_cache where field_name="ifbgpas" and snmp_query_id=1;

insert into host_snmp_cache
  select IP.host_id, IP.snmp_query_id, bgp.field_name, bgp.field_value, IP.snmp_index, bgp.oid, bgp.present, bgp.last_updated 
   from host_snmp_cache as bgp 
   join host_snmp_cache as nei using (host_id) 
   join host_snmp_cache as IP using (host_id) 
   where bgp.field_name="ifbgpas" 
    and nei.field_name="ifbgpnei" 
    and IP.field_name="ifIP" 
    and nei.field_value=IP.field_value 
    and bgp.snmp_index=nei.snmp_index 
   group by snmp_index;
This does have the limitation of only one BGP remote ASN per interface ifIndex, but meets my needs for the point-to-point links I manage (this won't work if you peer at an IX for example, or loopback peering, or in other cases where you have multiple bgp neighbor ASNs per interface).

What I'm hoping for now is to be able to automate that bit of SQL to execute after both of the data queries complete getting data from the device and before the automation for graph creation is triggered when hosts get re-indexed. I've looked a bit at the hook registration for plugin development, but it's not yet clear to me which is the right hook to use for this.
Post Reply

Who is online

Users browsing this forum: No registered users and 7 guests