網(wǎng)絡(luò)工程師需要學(xué)習(xí)新技能和使用自動(dòng)化工具才能適應(yīng)軟件定義網(wǎng)絡(luò)(SDN)的工作環(huán)境。
聽起來似乎很難,但是網(wǎng)絡(luò)工程師都很聰明。我們往往必須處理一些大型復(fù)雜網(wǎng)絡(luò),它們有越來越多的功能,并且是用數(shù)量更多的命令實(shí)現(xiàn)的。因此,千萬不要認(rèn)為我們自己學(xué)不會(huì)其他一些能幫助我們簡化工作和優(yōu)化網(wǎng)絡(luò)運(yùn)行的技能。設(shè)想一下你還不需要編程呢!看一下復(fù)雜的網(wǎng)絡(luò)配置。它是靠編程實(shí)現(xiàn)的,但是它以分布式的形態(tài)存在,因此要比一般的軟件系統(tǒng)更難維護(hù)。
要接受這個(gè)挑戰(zhàn),學(xué)習(xí)網(wǎng)絡(luò)工程師技能,然后每天學(xué)習(xí)多一點(diǎn),就像你在管理網(wǎng)絡(luò)一樣。
故障修復(fù)技能
網(wǎng)絡(luò)工程師的故障修復(fù)技能是很優(yōu)秀的,并且仍然會(huì)繼續(xù)發(fā)揮重要作用。然而,SDN要求他們提升一下自己的技能。網(wǎng)絡(luò)會(huì)變得越來越動(dòng)態(tài),因此他們需要自動(dòng)化系統(tǒng)和新工具去實(shí)時(shí)收集和分析必要的數(shù)據(jù)。由于應(yīng)用程序驅(qū)動(dòng)著網(wǎng)絡(luò)的變更,因此工程師必須更熟悉API,檢查SDN日志,將變化與問題癥狀相關(guān)聯(lián)。這個(gè)過程和我們以前知道的故障問題修復(fù)過程并沒有太大的差別。唯一的不同是這些故障修改技術(shù)會(huì)變得越來越普遍。網(wǎng)絡(luò)工程師應(yīng)該學(xué)習(xí)一些比ping、traceroute和“show configuration”更高級(jí)的工具。
基本的軟件工具技能
要學(xué)習(xí)如何駕馭一個(gè)好的文本編輯器。許多編輯器的命令多到難以全部記住,因此不要試圖記住所有東西。要關(guān)注于一些基本功能:鼠標(biāo)在字符、行、單詞和段落間的移動(dòng);文字修改和復(fù)制功能;以及文件保存和關(guān)閉功能。一旦熟悉了這些基本功能,就要增加多窗口命令和宏來提高生產(chǎn)力。只需要學(xué)習(xí)幾個(gè)小時(shí),我們就可以用少量的命令實(shí)現(xiàn)較高的生產(chǎn)效率。
要通過學(xué)習(xí)一些Linux操作系統(tǒng)經(jīng)驗(yàn)來繼續(xù)提升自己的網(wǎng)絡(luò)工程師技能。許多新硬件平臺(tái)(思科NX-OS、Arista EOS和Cumulus OS)都使用Linux作為控制系統(tǒng)。要學(xué)習(xí)基本的文件系統(tǒng)結(jié)構(gòu),因?yàn)檫@是系統(tǒng)配置文件所在的地方,并且也要學(xué)習(xí)如何修改文件系統(tǒng)結(jié)構(gòu)。首先要關(guān)注于修改網(wǎng)絡(luò)參數(shù),啟用或禁用服務(wù)器進(jìn)程(DHCP客戶端和服務(wù)器模式),通過SSH連接Linux命令行接口(CLI),以及執(zhí)行正確的Linux關(guān)機(jī)操作。要學(xué)習(xí)如何創(chuàng)建和修改cron作業(yè),這樣就可以編寫一些腳本按指定的時(shí)間重復(fù)執(zhí)行。學(xué)習(xí)Linux必須掌握基本的Bash腳本編程。
學(xué)習(xí)SDN中一種常用編程語言的軟件開發(fā),如Java、Python或C/C++等。一種語言的概念和技能通??梢杂|類旁通地應(yīng)用到其他語言上。Python是一種很容易學(xué)習(xí)的腳本語言。它具有面向?qū)ο蠊δ?,它可以幫助我們學(xué)習(xí)編程方法,但是我們不一定要從這個(gè)語言開始著手學(xué)習(xí)。要學(xué)習(xí)如何使用管道命令將多個(gè)小工具和腳本整合在一起來完成更大的任務(wù)。一個(gè)好例子就是重命名大量的文件,例如刪除“.txt”后綴并添加“.cfg”后綴。
最后,大多數(shù)開源項(xiàng)目都使用Git來維護(hù)它們的代碼,因此一定要學(xué)習(xí)如何它來存儲(chǔ)、獲取和存檔軟件項(xiàng)目。每一個(gè)項(xiàng)目通常帶有一個(gè)開發(fā)者郵件列表,從中可以跟蹤軟件更新,并且通常還有一個(gè)關(guān)于軟件使用的用戶郵件列表。
自動(dòng)化技能
這是一個(gè)大科目,因?yàn)樗宋幕淖?。網(wǎng)絡(luò)工程師已經(jīng)學(xué)會(huì)了如何通過編程一次處理一個(gè)設(shè)備的網(wǎng)絡(luò)。現(xiàn)在他們需要改變自己配置、監(jiān)控和管理網(wǎng)絡(luò)的方式。大多數(shù)網(wǎng)絡(luò)團(tuán)隊(duì)似乎都在抵觸自動(dòng)化,因?yàn)樗麄兒ε乱粋€(gè)小錯(cuò)誤就能把網(wǎng)絡(luò)破壞到無法在逐個(gè)設(shè)備上使用CLI將它修復(fù)回正常狀態(tài)。
可以從實(shí)現(xiàn)自動(dòng)的設(shè)備配置檢查開始,使用網(wǎng)絡(luò)變更與配置管理(NCCM)系統(tǒng)自動(dòng)地檢查所有網(wǎng)絡(luò)設(shè)備上正確配置的功能。首先,保證所有設(shè)備的簡單網(wǎng)絡(luò)管理協(xié)議(SNMP)和AAA配置與模板相匹配。然后,檢查特定類型設(shè)備的配置,如核心路由器或接入交換機(jī)。(注意:參見《設(shè)備與接口標(biāo)識(shí)》中關(guān)于設(shè)備與接口的分組方式。)
一旦實(shí)現(xiàn)自動(dòng)的設(shè)備與接口配置驗(yàn)證,就可以使用自動(dòng)化系統(tǒng)推送配置修改。要通過執(zhí)行一些簡單修改(如修改密碼)來熟悉這個(gè)過程。使用自動(dòng)配置修改少數(shù)設(shè)備,然后再確定有效的前提下擴(kuò)大應(yīng)用范圍。如果無效,則要修復(fù)問題,確定原因,然后再執(zhí)行。一開始時(shí),這個(gè)過程可能比手工處理還要耗費(fèi)時(shí)間,但是從中獲得的自動(dòng)化經(jīng)驗(yàn)可以應(yīng)用到更多的功能上,然后很快就有能力使用自動(dòng)化部署所有的配置修改。
SDN會(huì)將自動(dòng)化推上一個(gè)新高度。例如,應(yīng)用程序可以通知SDN控制器它的新需求,然后SDN控制器就會(huì)實(shí)現(xiàn)所需要的修改。理解當(dāng)前發(fā)生的變化,并且熟悉這個(gè)過程,這一點(diǎn)非常重要。
在我們獲得新的網(wǎng)絡(luò)工程師技能之后,還會(huì)遇到一些需要進(jìn)一步學(xué)習(xí)的陌生詞語和概念。這與學(xué)習(xí)其他的新網(wǎng)絡(luò)技術(shù)并無不同,如前門虛擬路由與轉(zhuǎn)發(fā)。但是,不用多長時(shí)間,我們就會(huì)熟悉網(wǎng)絡(luò)自動(dòng)化和腳本編寫,感覺就像在配置傳統(tǒng)網(wǎng)絡(luò)一樣。