溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

自己搭建自動(dòng)化巡檢系統(tǒng)(四) 處理鄰居列表

發(fā)布時(shí)間:2020-06-27 11:21:35 來(lái)源:網(wǎng)絡(luò) 閱讀:2257 作者:yerikyu 欄目:網(wǎng)絡(luò)管理

通過(guò)之前的三次實(shí)驗(yàn),我們已經(jīng)可以初步的使用python通過(guò)telnet來(lái)操作cisco設(shè)備,接下來(lái)開(kāi)始新一期的實(shí)驗(yàn)

實(shí)驗(yàn)?zāi)康模壕W(wǎng)絡(luò)巡檢,之后將信息存儲(chǔ)在數(shù)據(jù)庫(kù)中

本次實(shí)驗(yàn)需要再次拓展新的拓?fù)?,,且?shí)驗(yàn)環(huán)境改為ubuntu,后續(xù)的拓展將改為在linux環(huán)境下經(jīng)行。本地地址使用10.10.10.142,通過(guò)兩臺(tái)管理交換機(jī)來(lái)控制六臺(tái)路由器,其地址分配

R1

10.10.10.101

R2

10.10.10.102

R3

10.10.10.103

R4

10.10.10.104

R5

10.10.10.105

R6

10.10.10.106

自己搭建自動(dòng)化巡檢系統(tǒng)(四) 處理鄰居列表

為每臺(tái)設(shè)備配置IP地址

由于需要批量配置,可以使用CRT的全局發(fā)送功能實(shí)現(xiàn)批量命令部署

自己搭建自動(dòng)化巡檢系統(tǒng)(四) 處理鄰居列表

全部部署vty之后,開(kāi)通三臺(tái)設(shè)備以減少機(jī)器負(fù)擔(dān),后續(xù)再陸續(xù)開(kāi)發(fā)

自己搭建自動(dòng)化巡檢系統(tǒng)(四) 處理鄰居列表

檢驗(yàn)連通性

自己搭建自動(dòng)化巡檢系統(tǒng)(四) 處理鄰居列表

發(fā)現(xiàn)鄰居名單

自己搭建自動(dòng)化巡檢系統(tǒng)(四) 處理鄰居列表

檢驗(yàn)代碼的執(zhí)行結(jié)果

自己搭建自動(dòng)化巡檢系統(tǒng)(四) 處理鄰居列表

接下來(lái)的任務(wù)是通過(guò)系統(tǒng)抓包,對(duì)這些數(shù)據(jù)包進(jìn)行分析,我們的任務(wù)就是通過(guò)抓取cdp數(shù)據(jù)包的形式,記錄鄰居關(guān)系,如果發(fā)生鄰居關(guān)系變動(dòng)則發(fā)出告警信息。

這里說(shuō)一下思路:獲取接受的這串字符串,進(jìn)行信息處理,即只收取:R1 Fas0/0 Fas0/0,并存入本地?cái)?shù)據(jù)庫(kù)中,因此需要在數(shù)據(jù)庫(kù)中建立一張鄰居表,存儲(chǔ)路由器編號(hào)、本地接口號(hào),對(duì)端接口號(hào)。這里安裝兩個(gè)數(shù)據(jù)庫(kù),存儲(chǔ)在兩個(gè)地方,一來(lái)是災(zāi)備,二來(lái)是為了之后做實(shí)驗(yàn),測(cè)試關(guān)系型數(shù)據(jù)庫(kù)和非關(guān)系型數(shù)據(jù)庫(kù)的在運(yùn)行效率上的不同。

第一步:截取信息

處理這串字符:

'show cdp neighbors\r\nCapability Codes: R- Router, T - Trans Bridge, B - Source Route Bridge\r\n                  S - Switch, H - Host, I -IGMP, r - Repeater\r\n\r\nDevice ID       Local Intrfce     Holdtme    Capability Platform  Port ID\r\nR1               Fas 0/0            172        R S I      3640     Fas 0/0\r\nR6               Fas0/0            144        R S I      3640     Fas 0/0\r\nR4               Fas0/0            170        R S I      3640     Fas 0/0\r\nR2>'

本次打算使用的字符串處理方法是進(jìn)行切片,后續(xù)還可以嘗試使用類(lèi)似正則表達(dá)式的方法

自己搭建自動(dòng)化巡檢系統(tǒng)(四) 處理鄰居列表

等待2秒是需要接收設(shè)備返回的鄰居信息

自己搭建自動(dòng)化巡檢系統(tǒng)(四) 處理鄰居列表

處理完成,美滋滋

自己搭建自動(dòng)化巡檢系統(tǒng)(四) 處理鄰居列表

第二步:設(shè)計(jì)關(guān)系表,并建表

設(shè)計(jì)mysql

Database:NDB

Tablecdp_nei

RID

Char

Local_Int

Char

Port_ID

Char

First_record

Datetime

Change_record

Datetime

這里已經(jīng)在mysql中的ndb里面建立一張表,存儲(chǔ)的是cdp鄰居的信息,基于當(dāng)前的拓?fù)?,可以預(yù)見(jiàn)當(dāng)所有路由器運(yùn)行之后,表中的信息條目應(yīng)該是6*7=42

自己搭建自動(dòng)化巡檢系統(tǒng)(四) 處理鄰居列表

First_record用于記錄首次記錄這個(gè)數(shù)據(jù)項(xiàng)的時(shí)間,Change_record則會(huì)自動(dòng)記錄每次修改這個(gè)數(shù)據(jù)項(xiàng)的時(shí)間,在查詢的時(shí)候,可以通過(guò)查看修改數(shù)據(jù)項(xiàng)的時(shí)間,如果發(fā)生改變就可以直接提示這條鏈路發(fā)生抖動(dòng)

第三步:寫(xiě)入數(shù)據(jù)庫(kù)中

我們?cè)谡{(diào)試界面試一下該命令可以通過(guò)

自己搭建自動(dòng)化巡檢系統(tǒng)(四) 處理鄰居列表

查看效果

自己搭建自動(dòng)化巡檢系統(tǒng)(四) 處理鄰居列表

好了之后可以在代碼中寫(xiě)入相關(guān)指令,不過(guò)在這之前,先做一件刺激的事兒,先衫褲再跑路!

自己搭建自動(dòng)化巡檢系統(tǒng)(四) 處理鄰居列表

代碼:

這個(gè)是初始版本,后續(xù)為了開(kāi)發(fā)方便封裝在一個(gè)單獨(dú)的類(lèi)里面的

自己搭建自動(dòng)化巡檢系統(tǒng)(四) 處理鄰居列表

寫(xiě)完之后記得同步數(shù)據(jù)才可以在數(shù)據(jù)庫(kù)中查看到相關(guān)信息

自己搭建自動(dòng)化巡檢系統(tǒng)(四) 處理鄰居列表

寫(xiě)入成功,美滋滋啊

自己搭建自動(dòng)化巡檢系統(tǒng)(四) 處理鄰居列表

第四步:遍歷所有設(shè)備的鄰居信息

思路:依次telnet登錄每臺(tái)設(shè)備,對(duì)其使用show cdp nei,然后收集對(duì)端端口信息,寫(xiě)入數(shù)據(jù)庫(kù)中

自己搭建自動(dòng)化巡檢系統(tǒng)(四) 處理鄰居列表

這里就可以動(dòng)態(tài)的將信息存儲(chǔ)在數(shù)據(jù)庫(kù)中,下個(gè)實(shí)驗(yàn)我們將通過(guò)編寫(xiě)腳本,將出錯(cuò)的信息告警


關(guān)于python-mysql的安裝教程以及mysqldb這個(gè)工具包的使用筆記在評(píng)論中的連接


向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI