Netconf网络配置协议讲解

article/2025/11/10 6:31:19

目录

什么是Netconf

为什么要提出Netconf

数据的类别

传统网络配置协议

Netconf配置协议

Netconf协议架构

安全传输层

消息层

操作层

内容层

Netconf配置设备流程

通过Python进行Netconf配置

Restconf


什么是Netconf

NETCONF(Network Configuration Protocol)网络配置协议,提供一套管理网络设备的机制。用户可以使用这套机制增加、修改、删除网络设备的配置,获取网络设备的配置和状态信息。

NETCONF有三个对象

NETCONF客户端、NETCONF服务器、NETCONF消息


为什么要提出Netconf

数据的类别

运行在设备上可获取的信息分为两类:配置数据和状态数据

配置数据可以写(例如配置IP地址,此数据就是配置数据)

状态数据是只读数据(例如接口的带宽利用率无法改变,只能读取,此数据就是状态数据)

传统网络配置协议

更改设备数据有多种方法,可以基于命令行也可以基于特定协议。命令行和SNMP是最经典的获取设备数据的方法

SNMP

SNMP基于UDP协议,无状态、无序、不可靠

SNMP用Set做配置时支持的配置比较少,只能做简单的配置,配置的限制太大

SNMP只是单个设备的管理,不支持网络级的配置和多设备配置协同

SNMP使用MIB进行描述数据的,不区分是状态数据还是配置数据

SNMP其实主要还是用于网络监控,不适合设备管理

CLI

各厂商定义的CLI各不相同,管理不方便

CLI配置脚本人类容易理解,但是设备解析起来比较复杂,很难实现自动化解析

无论配置自动化技术如何发展,本质仍然是使用CLI

Netconf配置协议

Netconf工作在SSH协议之上(通过SSH进行加密),可以下发配置给网路设备

Netconf有标准的数据模型,统一数据格式,可以使得所有厂商都可以识别

Netconf相比CLI设备识别会更快速,可以兼容不同的厂商

Netconf是面向业务的,支持网络级的配置和多设备配置协同

Netconf会区分状态数据和配置数据


Netconf协议架构

Netconf协议在概念上可以划分为4层:安全传输层、消息层、操作层、内容层

出错了才会发送notification

安全传输层

为客户端和服务器之间交互提供通讯路径

当前华为Netconf协议的安全传输层是基于SSH

消息层

提供的是RPC请求和回应机制,表示此消息是RPC请求还是RPC应答

RPC的框架与传输层独立,用于表示Netconf requests和response

设备之间的会话交互是有会话ID的

消息层的格式

<rpc>

用于封装从客户端到服务端的NETCONF请求(头部定义message-id标示序列)

<rpc-reply>

用户服务端回复<rpc>的response消息(头部message-id与<rpc>保持一致)

<rpc-error>在<rpc-reply>中被发送

一个<rpc-reply>可以包含多个<rpc-error> , 表示没有错误

<ok>在<rpc-reply>中被发送

表示没有数据返回

操作层

明确消息层中的内容是干嘛的(进行配置edit(删除、创建、修改等配置)、下载get等)

操作对象(Netconf有三个操作对象)

运行配置库(running)-dis cu可以查看

 命令配置成功,并且comit了,配置的命令就会存储在运行配置库中

 此配置库存放在内存中

候选配置库(candidate)

 命令配置成功,但是没有comit,配置的命令会就存储在候选配置库

启动配置库(startup)-dis save可以查看

 配置命令保存后,配置的命令就会存储在启动配置库中

 此配置库存放在Flash卡中

通过此三个配置库,可以灵活读取和编辑配置库、候选库与运行库,实现整体配置的下发、验证和回滚

Netconf定义的操作类型

操作类型和操作对象之间的关系

内容层

为设备配置数据的具体才足以内容,即下载或配置的具体内容(配置某个接口,下载某个文件)

建模语言

当前Netcon有两种建模语言:Schema和Yang

Schema

Schema是为了描述XML文档而定义的一套规则

Schema文件中定义了设备所有管理对象,以及管理对象的层次关系、读写属性和约束条件

Yang—主要使用的是Yang建模语言

YANG是专门为NETCONF协议设计的数据建模语言

用来为NETCONF协议设计可操作的配置数据、状态数据模型、远程调用(RPCs)模型和通知机制等

什么是Yang模型,Yang和Netconf的关系是什么

Yang是一个建模的语言,只有框架,没有具体的数据,用来描述Netconf的内容层的结构

NETCONF 1.0对模型语言没有要求,NETCONF1.1明确了与YANG结合,开始规范NETCONF内容格式。

虽然指定了标准的Yang,但是每个厂商都有自己私有的Yang,在使用Netconf配置时并未完全统一

设备里面会内置了很多的Yang模型,不同的Yang模型只表示内容层不一样,其他层是一样的

当前华为设备支持的内容层

Huawei-YANG     华为私有Yang

NETCONF Schema 

Openconfig-yang  谷歌牵头的Yang

IETF-Yang         标准的Yang


Netconf配置设备流程

Netconf如何对设备配置

向Yang建模文件中填充数据,将其转为XML格式下发到设备进行设备配置

因为Yang语言只定义了模型,没有数据,要生成数据就需要变为XML格式(<>)

即将数据填充到Yang模型中,将其转变为XML格式(Yang转XML)

XML类似于Html,是一种扩展的标记语言

为什么要转为XML语言

       因为很多设备是支持XML语言的

XML格式编码

XML是Netconf协议的编码格式

例子:通过Netconf下发Vlan配置(内容层为Huawei私有Yang)

其中merge是<config>中可选的“operation”属性中的一个操作

Operation包含的操作以及其作用

merge:(默认操作)

在数据库中修改存在或不存在的目标数据

如果目标数据不存在则创建,如果目标数据存在则修改

create

当且仅当配置数据库中不存在待创建的配置数据时,才能成功添加到配置数据库

如果配置数据存在,则会返回<rpc-error>(其中包含一个<error-tag>值“data-exists”)

delete

删除配置数据库中指定的配置数据记录

如果数据存在,则删除该数据,如果数据不存在,则返回<rpc-error>(其中包含一个<error-tag>值“data-missing”)

remove

删除配置数据库中指定的配置数据记录

如果数据存在,则删除该数据,如果数据不存在,则返回成功。

delete和remove有点不同,一般删除使用remove


通过Python进行Netconf配置

Python中ncclient模块主要就是用来下发Netconf配置的(代码若有不对请指正)

基本步骤

ssh要手工配置好

先通过Prami模块通过SSH登录上去,配置Netconf相关命令(开启设备Netconf)

然后在通过ncclient模块下发Netconf配置

Netconf.txt文件

sys im
aaalocal-user netconf password irreversible admin@123local-user netconf service-type sshlocal-user netconf level 15quitrsa local-key-pair create
yssh user netconf service-type snetconf
snetconf server enable
netconfprotocol inbound ssh port 830quit

实验命令

from ncclient import manager
from ncclient import operations
import paramiko
import timeip = "192.168.0.1"
ssh_user = "huawei"
ssh_password = "admin@123"netconf_port = '830'
netconf_user = 'netconf'
netconf_password = 'admin@123'
filename = r'netconf.txt'    #此文件夹存放的是关于Netconf的命令(设备开启Netconf相关操作)#声明类名为ssh,包含两个方法 ssh_connect()建立SSH连接,ssh_config发送配置
class ssh():def ssh_connect(ip,username,password):ssh = paramiko.client.SSHClient()ssh.set_missing_host_key_policy(paramiko.client.AutoAddPolicy)ssh.connect(hostname=ip,port=22,username=username,password=password)print(ip+"ssh登录成功")return sshdef ssh_config(filename,ip,username,password):a = ssh.ssh_config(ip,username,password)command = a.invoke_shell()command.send("N\n")command.send("screen-length 0 temporary \n")with open(filename) as cmd1:cmd = cmd1.readlines()for i in cmd:command.send(i)time.sleep(1)outup = command.recv(65535).decode('ascii')print(outup)a.ssh_close()#建立Netconf会话连接
def huawei_connect(ip,port,user,password):return manager.connect(ip = ip,port = port,username = user,password = password,hostkey_verify = False,device_params = {'name' : 'huaweiyang'},allow_agent = False,look_for_keys = False)
#Netconf配置文件 Yang为huawei-yang,XML格式
CREATE_INTERFACE = '''<config><ifm xmlns="urn:huawei:yang:huawei-ifm"> <interfaces> <interface> <name>100GE1/0/1</name><mtu>1500</mtu> </interface> </interfaces> </ifm></config>'''if __name__ == "__main__":ssh.ssh_config(filename,ip,ssh_user,ssh_password)m = huawei_connect(ip,netconf_port,netconf_user,netconf_password)m.edit_config(target="running",config=CREATE_INTERFACE)m.commit()

Restconf

Restconf和Netconf的对比

Netconf有事务机制,可以回滚;Restconf无状态,无事务机制,不可以回滚

Netconf主要运行在运营商;Restconf主要用在互联网厂商

Netconf需要通过客户端进行配置下发;Restconf通过Web就可以实现(HTTP协议)

 

Restconf和Netconf实现的作用是类似的


http://chatgpt.dhexx.cn/article/NEESMHPP.shtml

相关文章

netconf协议

最近项目中要用到netconf协议也和设备之间进行连接&#xff0c;学习一下netconf协议并且记录下来 一&#xff1a;什么是netconf netconf协议也可以叫做网络配置协议&#xff0c;它提供了一套管理网络设备的机制&#xff0c;用户可以使用这套机制增加&#xff0c;修改&#xff0…

neq的问题

最近做一个项目&#xff0c;用的tp5&#xff0c;刚开始上手&#xff0c;就给我出现了一个莫名其妙的问题&#xff1b; 也不算是错误&#xff0c;看代码 我根据这个条件去用select查询数据库的数据&#xff0c;然后居然只给我返回一条数据&#xff0c;我以为是我的查询语句写错…

php条件判断结构一个嵌套,thinkphp:html中的if condition 嵌套写法、条件判断的各种情况(eq、neq、gt、lt、or、and) - 猫扑天空...

伪代码 术语符号 大于 gt 小于 lt 等于 eq 不等于 neq 或者 or 并且 and 变量start_time代表的含义是活动的开始时间,变量start_time代表的含义是活动的结束时间。两个变量都是时间戳的格式。下面就将显示状态一列的数据&#xff0c;各种情况下的判断条件列举出来。 等于 eq 进…

前端模板标签eq与neq的使用,以及管理系统模块权限控制

1&#xff09;方法一&#xff1a; 在超级管理员登录情况下显示 1.当前登录用户只能修改自己 2.超级管理员admin拥有查看普通用户和删除其他用户的权限&#xff0c;但删除不了自己 {volist name"userList" id"user" empty"$empty"}<tr><…

2022-03-11 工作记录--PHP-eq(表示等于)、 neq(表示不等于)

PHP-eq&#xff08;表示等于&#xff09;、 neq&#xff08;表示不等于&#xff09;

mysql neq什么意思_【知识科普】标准中的Eqv、Idt和Neq分别代表什么?

对于接触标准化的工作者&#xff0c;每日避免不了和各种各样类别的标准打交道。除了标准的分类&#xff0c;分级、层次等问题&#xff0c;一些特殊的英文字符&#xff0c;也许让很多标准化人员产生困惑&#xff0c;接下来&#xff0c;请允许小编花一些时间&#xff0c;跟您详细…

Flyway针对多数据源配置实战方案

Flyway针对多数据源配置实战方案 介绍 这篇文章主要介绍Flyway、Druid和多数据源结合起来如何配置和使用的方案。网上一些文章似乎都没有达到一开始我自己琢磨想要的程度&#xff0c;还是自己琢磨和调试出来了一套方案&#xff0c;欢迎大家斧正。 引入pom文件 首先引入对应…

Flyway学习和使用

1、什么是Flyway Flyway is an open-source database migration tool. It strongly favors simplicity and convention over configuration. It is based around just 7 basic commands: Migrate, Clean, Info, Validate, Undo, Baseline and Repair. Flyway是一款开源的数据…

flyway baseline-version

背景 使用flyway进行数据库版本控制。 问题 flyway配置 # 当迁移发现数据库非空且存在没有元数据的表时&#xff0c;自动执行基准迁移&#xff0c;新建schema_version表baseline-on-migrate: true# 开始执行基准迁移时对现有的schema的版本打标签&#xff0c;默认值为1basel…

Ruoyi集成flyway后启动报错的解决方法

ruoyi系列框架是开源中非常好的源码平台&#xff0c;使用宽松的开源协议进行源代码的开放。不管是单体版、前后端分离甚至是微服务架构&#xff0c;均提供了相应的代码。基于ruoyi可以做自己的后台系统&#xff0c;也可以学习很多技术的集成。 而flyway是java里面的数据库脚本…

快速掌握和使用Flyway

什么是Flyway? 转载&#xff1a;https://blog.waterstrong.me/flyway-in-practice/ Flyway is an open-source database migration tool. It strongly favors simplicity and convention over configuration. Flyway是一款开源的数据库版本管理工具&#xff0c;它更倾向于规约…

flyway使用说明

Flyway是一款数据库迁移&#xff08;migration&#xff09;工具。简单点说&#xff0c;就是在你部署应用的时候&#xff0c;帮你执行数据库脚本的工具。Flyway支持SQL和Java两种类型的脚本&#xff0c;你可以将脚本打包到应用程序中&#xff0c;在应用程序启动时&#xff0c;由…

Flyway 入门教程

目录 一、简单介绍 二、Flyway使用场景 三、Flyway工作原理 四、Flyway如何校验文件 五、使用Flyway 5.1 引入依赖 5.2 添加配置 5.2.1 SpringBoot配置 5.2.2 SpringMVC配置 5.3 脚本准备 六、使用Maven插件 七、特别说明 一、简单介绍 Flyway 是一款开源的数据库…

SpringBoot引入Flyway,及Flyway简单了解

Flyway 中的常用概念 Flyway 中的概念可查阅 官方文档&#xff0c;这里挑选一些重要的进行简单介绍。 Schema History Table Flyway 对数据库进行版本控制的方式&#xff0c;是在指定数据库中创建一张表&#xff0c;即 Schema History Table&#xff08;默认为 flyway_schem…

Flyway详解以及Springboot集成Flyway

Flayway是一款数据库版本控制管理工具&#xff0c;&#xff0c;支持数据库版本自动升级&#xff0c;Migrations可以写成sql脚本&#xff0c;也可以写在java代码里&#xff1b;不仅支持Command Line和java api &#xff0c;也支持Build构建工具和Spring boot&#xff0c;也可以在…

spring-cloud集成数据库版本迁移工具flyway

spring-cloud集成数据库版本迁移工具flyway Flyway实现数据库版本同步有两种方式&#xff0c;一种就是直接导包&#xff0c;通过配置文件使用&#xff0c;还有一种就是自定义的方式。一 、依赖配置文件 1 flyway实现sql初始化 1.1 首先需要添加依赖 <!--mysql数据库版本…

Flyway 数据库版本控制

背景 在我们日常产品发布的过程中&#xff0c;代码的版本控制可以使用git、svn工具实现。对于数据库每当发布时会出现手动执行sql脚本进行升级数据库&#xff0c;中间经常出现一些漏写、错写情况&#xff0c;对数据库的版本与代码的版本不匹配&#xff0c;导致上线后出现数据库…

FlyWay入门教程

文章目录 Flyway1. 概述2. 工作原理与基本概念工作原理概述基本概念**[Migration(迁移)](https://flywaydb.org/documentation/concepts/migrations#naming)** 3. 安装和基本使用命令行安装使用命令 Java APISpring Boot Flyway Flyway by Redgate • 数据库迁移变得简单。 ---…

flyway的学习

Flyway 是一款开源的数据库版本管理工具。管理数据库变更的版本。 flyway工作流程如下&#xff1a; 项目启动&#xff0c;应用程序完成数据库连接池的建立后&#xff0c;Flyway自动运行。初次使用时&#xff0c;flyway会创建一个flyway_schema_history 表&#xff0c;用于记录…

Flyway的简单介绍及使用

Flyway的简单介绍及使用 一、开发时管理数据库遇到的问题&#xff1a; 现在开发一般都是团队开发&#xff0c;这样就会出现项目同步的问题&#xff0c;代码同步可以通过SVN工具管理起来&#xff0c;那数据库同步怎么办呢&#xff1f;理想的情况下&#xff0c;在开发新项目的时…