繼之前分享的幾篇文章之后,這篇文章分享自己對于YANG模型的理解。關(guān)于其他如何搭建環(huán)境以及編寫app等等請閱讀下前幾篇文章。
早在2003年,IETF成立了一個(gè)NETCONF工作組,提出一種基于xml的網(wǎng)絡(luò)配置管理協(xié)議,也就是NETCONF(Network Configuration PRotocol),因?yàn)樵搮f(xié)議的配置功能非常強(qiáng)大,同時(shí)兼顧監(jiān)控和故障管理,安全驗(yàn)證和訪問控制,所以得到業(yè)界的一致認(rèn)可,所以廣泛采用netconfig來配置網(wǎng)絡(luò)。
NETCONF協(xié)議分為傳輸層、RPC層、操作層和內(nèi)容層。其中,內(nèi)容層是唯一沒有標(biāo)準(zhǔn)化的層,于是一種新的建模語言YANG產(chǎn)生了,它的目標(biāo)是對NETCONF數(shù)據(jù)模型、操作進(jìn)行建模,覆蓋NETCONF協(xié)議的操作層和內(nèi)容層
module是YANG的基本單元,是寫yang文件的基本框架,包括以下幾種類型語句:1、head語句(yang-version/namespace/prefix)2、連接語句(import/include)、3、元信息(organization/contract)、4、revision語句、5、定義語句(container/leaf/leaf-list/grouping等等)。YANG模塊有如下的布局:
java12345678910111213141516171819202122 | module <module-name> {//header informationyang-version statementnamespace statementprefix statement // linkage statementsimport statementsinclude statements // meta informationorganization statementcontact statementdescription statementreference statement // revision historyrevision statements // module definitionsother statements} |
例如:
submodule是部分模塊定義,用于對模塊提供支持。submodule文件內(nèi)容布局如下:
Java12345678910111213141516171819202122 | submodule<module-name>{yang-versionstatement // module identificationbelongs-tostatement // linkage statementsimportstatementsincludestatements // meta informationorganizationstatementcontactstatementdescriptionstatementreferencestatement // revision historyrevisionstatements // module definitionsotherstatements} |
submodule示例如下:注意:submodule必須通過belongs-to語句使用, submodule只能由belong-to指定的module或這個(gè)指定module的其它submodule進(jìn)行include,其它module(包括submodule)都不能include。同時(shí)子模塊不可以import它的父模塊
module中必須定義所有節(jié)點(diǎn)都屬于一個(gè)特定的XML命名空間,由一個(gè)URI指定命名空間。例如
import或include語句包含一個(gè)revision-date的子句,所有引入的YANG定義來自要導(dǎo)入或引入的指定revision模塊。通過引入特定的模塊修訂,我們可以獨(dú)立發(fā)布演變中的模塊。YANG提供了指定的規(guī)則,如何發(fā)布進(jìn)化中的模塊并且保持向后的兼容性。比如:
基本數(shù)據(jù)類型YANG基本數(shù)據(jù)類型如下。
類別 | 類型 | 限制 |
Integral | Integral {u,}int{8,16,32,64} | range |
Decimals | decimal64 | range, fraction-digits |
String | string | length,pattern |
Enumeration | enumeration | enum |
Bool and Bits | boolean, bits |
|
Binary | binary | length |
References | leafref | path |
References | identityref | base |
References | instance-identifier |
|
Other | union |
|
Other | empty |
更加詳細(xì)的描述請參看rfc6020協(xié)議,例如
YANG采用typedef語句來定義派生類型。例如以下是定義一個(gè)派生類型percent,限制類型是內(nèi)建類型uint8:
Java123456789101112 | typedefpercent{typeuint8{range"0 .. 100";}}再如定義一個(gè)ip-address類型,它包含了兩個(gè)派生類型的聯(lián)合:typedefip-address{typeunion{typeipv4-address;typeipv6-address;}} |
leaf定義的節(jié)點(diǎn)只有一個(gè)值,是一個(gè)葉子節(jié)點(diǎn),只能有一個(gè)實(shí)例。例如:
leaf-list定義一組相同類型的葉節(jié)節(jié)點(diǎn),類似數(shù)組。與leaf區(qū)別在于leaf只有一個(gè)實(shí)例,而leaf-list可以有多個(gè)實(shí)例。例如:
container主要定義一個(gè)schema樹的內(nèi)部節(jié)點(diǎn),它本身沒有任何值和意義,只是作為一系列子節(jié)點(diǎn)的父親存在,只有一個(gè)實(shí)例。例如
list描述了一組節(jié)點(diǎn)的集合,它像一張數(shù)據(jù)庫表一樣,表的每一行用key來標(biāo)識其主鍵,有多個(gè)實(shí)例。例如
一個(gè)grouping定義一個(gè)可以重復(fù)使用的節(jié)點(diǎn)集合,使用時(shí)通過use語句,并可通過refine語句進(jìn)行改進(jìn)。例如使用grouping時(shí),通過use語句,它會將grouping定義的節(jié)點(diǎn)復(fù)制到當(dāng)前的schema樹(如果有refine,并進(jìn)行更新)。
一個(gè)choice節(jié)點(diǎn)定義了一個(gè)可供選擇項(xiàng)的集合,每一個(gè)選擇項(xiàng)都會在某種情況下存在。一個(gè)choice由許多分枝,通過case子語句定義。比如
anyxml表示任何未知的數(shù)據(jù)定義。
YANG提供augment語句,擴(kuò)大一個(gè)模塊層次,將節(jié)點(diǎn)添加到一個(gè)已存在的模塊或子模塊當(dāng)中。目標(biāo)結(jié)點(diǎn)可以是一個(gè)container, list, choice, case, rpc, input, output, notification等。
augment可以是條件的,使用when語句,當(dāng)特定條件滿足時(shí),新節(jié)點(diǎn)才會出現(xiàn)。
notification語句用來定義Notification內(nèi)容,內(nèi)容數(shù)據(jù)的定義同YANG數(shù)據(jù)定義一樣。下面例子使用上文例子定義的connection。
rpc語句用來定義NETCONF協(xié)議的RPCs,input和output使用YANG數(shù)據(jù)定義語句。如下例子,建模一個(gè)激活軟件圖片的RPC:
作者簡介:鴻哥,碩士研究生,國內(nèi)某通信設(shè)備公司軟件研發(fā)工程師,主要從事云計(jì)算、SDN技術(shù)開發(fā)
本文鏈接:http://www.sdnlab.com/18066.html
新聞熱點(diǎn)
疑難解答