RFC 5277 笔记

1. Introduction

本文档定义了如何向 NETCONF 协议提供异步消息 notification 传输。
这是 NETCONF 基本定义之上的可选能力。
本文档定义了实行此服务所必要的 capability 和 operation。

名词定义:

  • Element :一个 XML Element。
  • Subscription:通过 NETCONF session 接收 event notification 的一份 agreement 和 method。与此相关的概念还有 destination 和 selection of notification。它们与此 session 的绑定时间是整个 lifetime。
  • Event:一些发生的你可能感兴趣的东西,如 configuration change,fault,change in status,某临界值被突破,系统中来自外部的输入等等。
  • Replay:当收到 send/re-send 之前记录的 notification 的请求时,能将其发出的能力。
  • Stream:event stream 即满足一些转发标准,能被 NETCONF client 订阅的一个 event notification 集合。
  • Filter:表明在所有的 event 中,订阅者对哪些 event 感兴趣。

一些规则:

  • notification 应可以与 configuration operation 使用同一个 model。
  • notification 中的信息应该足以分析发生的事件。也就是说,读者可以完全不关心此 notification 是如何实现的,用了什么协议与什么传输机制。
  • 注意,一个 subscription 被创建之后就无法被修改,直到 session 终止,或者 subscription 因某种原因终止。

2. Notification-Related Operations

Subscribing
“订阅”由 NETCONF client 发起,由 NETCONF server 回复。
订阅在其整个生命期间,只与一个 stream 绑定。

<create-subscription>
此 operation 初始化了一个订阅。
其参数有:

  • Stream (optional,指定订阅哪个 stream。若未指定,则订阅 default stream)。
  • Filter (optional,指定哪些 event 被订阅。此参数的格式与 NETCONF protocol operation 中的 filter 一样。 若未指定,则订阅所有未被其他参数排除的 event)。
  • Start Time (optional, 表明支持 Replay 机制,以及从何时开始的 logged notification 可以被 re-send。 此参数指定的时间不应晚于当前时间。此参数的格式为 dateTime(RFC3339)。实现中应支持 time zones)。
  • Stop Time (optional, 必须与start time 配合使用,表示订阅机制持续到何时。其指定的时间必须晚于 start time。 若未设置,则订阅将会一直持续到被终止。)

成功的回复:
server 返回一个 <ok> element。
失败的回复:
在 <rpc-reply> 中包含一个 <rpc-error>。

Memo中提供了订阅的例子,见 2.1.1.1。

Sending notifications
<notification>
当订阅的事件发生时,向订阅的 client 发送通知。
其参数有:

  • eventTime 事件发生的时间。格式为 dateTime。

除了 eventTime 之外,notification 中包含什么内容不在本文档的范围中。

此消息无需回复。

Terminating subscription
取消 subscription 可以用 <close-session> ,或者通过另一个 session 使用 <kill-session> 终止 NETCONF session 或终止下层的传输session。
若订阅创建时设置了 stop time,则到了 stop time 指定的时间时 subscription 便会终止。 此时, NETCONF session 仍会是个 active session。

3. Supporting Concepts

Capabilities Exchange
在 NETCONF client 和 server 进行 capability exchange 的时候,event notification 相关的处理、发送的能力会被 advertised。
此能力的标识为 "urn:ietf:params:netconf:capability:notification:1.0"
以下为例子:

   <hello xmlns="urn:ietf:params:xml:ns:netconf:base:1.0">
     <capabilities>
        <capability>
            urn:ietf:params:xml:ns:netconf:base:1.0
        </capability>
        <capability>
            urn:ietf:params:netconf:capability:startup:1.0
        </capability>
        <capability>
            urn:ietf:params:netconf:capability:notification:1.0
        </capability>
     </capabilities>
     <session-id>4</session-id>
   </hello>

Event Streams
一个 event stream 即一组满足特定转发条件的 event notification 的集合。

在实际工作中,各种 system component 会产生各种 event notification,它们被统一发送到 central component 以进行分类和分发。 Central component 会根据 event notification 是否满足 event stream 的定义来判断此 event notification 是否属于某一 event stream。 一个 event notification 可以同时属于多个 event stream。
当 NETCONF server 收到来自 stream 的 event 后,会将其转换为对应的 XML 编码,组成 <notification>,将其发送到订阅此 stream 的所有 NETCONF session 的对端(此流程中 NETCONF server 还得考虑 filter)。
notification 日志记录服务也许应该提供,以满足可选的 replay 机制。

Event stream 是由被操控的设备预先定义的。对 event stream 的配置不在本文考虑范围内。
在目前的设想中,event stream 是由设备厂商预定义,并可由用户配置。设备厂商也许能支持通过 NETCONF protocol 配置 event stream (通过 <edit-config> 操作)。

支持 notification 能力的 NETCONF server 必须支持 “NETCONF” notification event stream。
This stream contains all NETCONF XML event notifications supported by the NETCONF server.
The exact string "NETCONF" is used during the advertisement of stream support during the <get> operation on <streams> and during the <create-subscription> operation.

NETCONF client 可通过对 <streams> subtree 的 <get> 操作从 NETCONF server 处取得支持的 event stream 列表。
结果的 event stream 信息通过 <name> 和 <description> 传递。 <name> 是必需的,且其 value 在整个 NETCONF server 中应是唯一的。
更多有关 stream 的信息还有 repaly 是否支持。 以及如果支持的话,可 replay 的最早 notification 的时间戳等。

以下是取得可用 event stream 列表的例子

<rpc message-id="101" xmlns="urn:ietf:params:xml:ns:netconf:base:1.0">
  <get>
   <filter type="subtree">
     <netconf xmlns="urn:ietf:params:xml:ns:netmod:notification">
        <streams/>
     </netconf>
   </filter>
  </get>
</rpc>

返回的例子详见 3.2.5.1。

NETCONF client 进行 <create-subscription> 操作时应指定订阅的 event stream。 若没有指定,则将订阅 default NETCONF event stream。

Replay
Replay 是在一个订阅中,将已发送过的 notification 重新发送的能力,或在某些情况下将 notification 首次发到特定 NETCONF client。

在支持 replay 的 notification stream 中,我们并不期望支持对 notification 无限制的记录。 NETCONF client 可以通过查询 <replayLogCreationTime> 和 <replayLogAgedTime> 获得可被 replay 的 notification 的相关信息。

记录的 notification 的具体数目由 NETCONF server 的实现自行确定。 对这方面的控制参数也不在本文考虑范围内。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 221,635评论 6 515
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 94,543评论 3 399
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 168,083评论 0 360
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,640评论 1 296
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,640评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 52,262评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,833评论 3 421
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,736评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,280评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,369评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,503评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 36,185评论 5 350
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,870评论 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,340评论 0 24
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,460评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,909评论 3 376
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,512评论 2 359

推荐阅读更多精彩内容