基于SNMP的路由拓扑发现算法收集
一、三层(网络层)发现
算法来源:王娟娟.基于SNMP的网络拓扑发现算法研究.武汉科技大学硕士学位论文,2008
数据结构:
待检路由设备网关链表:存放指定深度内待检路由设备的网关信息,处理后删除。
拓扑信息链表:存放从已检测路由设备的网关信息。
子网信息链表:存放网关信息对应的子网信息。
基本思想:
类似于广度优先,在指定深度内运行算法,最后根据拓扑信息链表获得所有路由及其互联关系,根据子网信息链表各路由设备连接的子网及子网内所有活动主机的信息。
需要获得的信息:
路由信息如下图所示。
点击可查看补充说明。
路由表中的每个条目都包含ipRouteDest、ipRouteIfIndex、ipRouteNextHop、ipRouteType和ipRouteMask这几项。其中,ipRouteDest表示路由的目的地址,ipRouteMask表示路由目标地址的子网掩码,将ipRouteDest和ipRouteMask按位与可以得到路由目标地址所在的子网;ipRoutelflndex表示路由本地接口的索引值,三层设备将目的地址为ipRouteDest的IP包通过该接口转发;ipRouteType表示了路由的类型,当路由类型值为3(direct)时,说明三层设备直接连接到路由目的地址所在子网,当路由类型值为4 (indirect)时,说明三层设备不直接连接到路由目的地址所在子网,必须再经过其它三层设备,即为路由表中的ipRouteNextHop,此时三层设备通过本地接口ipRoutelflndex与下一跳三层设备直接连接。
算法流程:
(1)初始化三个链表。
(2)向初始路由设备发送PDU征询数据包,从初始路由设备返回的应答数据包解析出每条记录中的路由相关信息:若当前记录的ipRouteType值为3,则将ipRouteNextHop值加进拓扑信息链表,将ipRouteNextHop、ipRouteDest、ipRouteMask、ipRoutelflndex、ifDescr值加进子网信息链表;若当前记录的ipRouteType值为4,则将ipRouteNextHop和ipAdEntAddr值加进拓扑信息链表,若待检设备网关链表中无节点的IP地址与此ipRouteNextHop相同,则将ipRouteNextHop加进待检设备网关链表,将该节点的跳数值赋为2,表示该路由设备距本地网关所在设备有一跳距离。
(3)在待检设备网关链表不为空且当前节点的深度不大于指定获取深度的情况下,继续进行下述处理:取出待检设备网关链表当前节点记录的ipRouteNextHop,封入PDU征询数据包发给相应路由设备,从设备返回的应答数据包解析出每条记录中的路由相关信息:若当前记录的ipRouteType值为3,则将ipRouteNextHop值加进拓扑信息链表,将ipRouteNextHop、ipRouteDest、ipRouteMask、ipRoutelflndex、ipDescr值加进子网信息链表;若当前记录的ipRouteType值为4,则将ipRouteNextHop和ipAdEntAddr值加进拓扑信息链表,若子网信息链表中无节点的IP地址与此ipRouteNextHop相同,则将ipRouteNextHop)JH进待检设备网关链表,将该节点的跳数加一。
(4)从待检设备网关链表中删除当前已被处理过的节点并判断是否继续处理。
以上算法会在搜索过程到达指定深度后停止,通过检索拓扑信息链表,便可得到该深度范围内所有路由设备的拓扑结构。
作者:五岳
出处:http://www.cnblogs.com/wuyuegb2312
对于标题未标注为“转载”的文章均为原创,其版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。