- 基于YANG的可编程网络:用YANG、NETCONF、RESTCONF和gNMI实现网络自动化架构
- (美)贝诺特·克莱斯 乔·克拉克 简·林德布拉德
- 412字
- 2021-09-29 10:28:16
2.8 服务器架构:数据存储
在典型的基于YANG的解决方案中,客户端和服务器由YANG模块的内容驱动。服务器将模块定义为NETCONF/RESTCONF引擎可用的元数据。引擎处理传入的请求;使用元数据来解析和验证请求;执行请求的操作;并将结果返回给客户端,如图2-5所示。
图2-5 服务器架构(RFC6244)
对特定问题域建模的YANG模块被加载、编译或编码到服务器中。
典型的NETCONF客户端/服务器事件交互的流程如下:
1. 客户端应用打开与服务器(设备)的NETCONF会话。
2. 客户端和服务器交换<hello>消息,其中包含双方支持的功能列表。hello交换消息包括服务器支持的YANG1.0模块列表。
3. 客户端在NETCONF的<rpc>元素中构建并发送以XML编码的YANG模块中定义的操作。
4. 服务器接收并解析<rpc>元素。
5. 服务器根据YANG模块中定义的数据模型验证请求的内容。
6. 服务器执行请求的操作,可能更改配置数据存储。
7. 服务器构建响应消息,包含响应本身、任何请求的数据以及任何错误的返回码。
8. 服务器在NETCONF的<rpc-reply>元素中发送以XML编码的响应。
9. 客户端接收并解析<rpc-reply>元素。
10. 客户端检查响应,并根据需要进行处理。