您好,登錄后才能下訂單哦!
通過(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 |
為每臺(tái)設(shè)備配置IP地址
由于需要批量配置,可以使用CRT的全局發(fā)送功能實(shí)現(xiàn)批量命令部署
全部部署vty之后,開(kāi)通三臺(tái)設(shè)備以減少機(jī)器負(fù)擔(dān),后續(xù)再陸續(xù)開(kāi)發(fā)
檢驗(yàn)連通性
發(fā)現(xiàn)鄰居名單
檢驗(yàn)代碼的執(zhí)行結(jié)果
接下來(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á)式的方法
等待2秒是需要接收設(shè)備返回的鄰居信息
處理完成,美滋滋
第二步:設(shè)計(jì)關(guān)系表,并建表
設(shè)計(jì)mysql
Database:NDB
Table:cdp_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
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ò)
查看效果
好了之后可以在代碼中寫(xiě)入相關(guān)指令,不過(guò)在這之前,先做一件刺激的事兒,先衫褲再跑路!
代碼:
這個(gè)是初始版本,后續(xù)為了開(kāi)發(fā)方便封裝在一個(gè)單獨(dú)的類(lèi)里面的
寫(xiě)完之后記得同步數(shù)據(jù)才可以在數(shù)據(jù)庫(kù)中查看到相關(guān)信息
寫(xiě)入成功,美滋滋啊
第四步:遍歷所有設(shè)備的鄰居信息
思路:依次telnet登錄每臺(tái)設(shè)備,對(duì)其使用show cdp nei,然后收集對(duì)端端口信息,寫(xiě)入數(shù)據(jù)庫(kù)中
這里就可以動(dòng)態(tài)的將信息存儲(chǔ)在數(shù)據(jù)庫(kù)中,下個(gè)實(shí)驗(yàn)我們將通過(guò)編寫(xiě)腳本,將出錯(cuò)的信息告警
關(guān)于python-mysql的安裝教程以及mysqldb這個(gè)工具包的使用筆記在評(píng)論中的連接
免責(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)容。